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

:root {
  --bg:     #06060a;
  --s1:     #0e0e14;
  --s2:     #131318;
  --s3:     #1a1a22;
  --bd:     rgba(255,255,255,0.065);
  --bdh:    rgba(255,255,255,0.13);
  --t1:     #eaeaf2;
  --t2:     #8888a0;
  --t3:     #44445a;
  --blue:   #5090f8;
  --teal:   #2dd4a0;
  --amber:  #f5a623;
  --red:    #e05c6e;
  --violet: #9080fa;
  --cyan:   #38c4e8;

  /* Theme transition */
  --theme-transition: background .3s, color .3s, border-color .3s, box-shadow .3s;
}

/* ─── LIGHT THEME ─── */
[data-theme="light"] {
  --bg:     #f0f0f5;
  --s1:     #e8e8f0;
  --s2:     #dddde8;
  --s3:     #d0d0de;
  --bd:     rgba(0,0,0,0.08);
  --bdh:    rgba(0,0,0,0.16);
  --t1:     #18181e;
  --t2:     #55556a;
  --t3:     #9090aa;
  --blue:   #2e6ef5;
  --teal:   #0fad7e;
  --amber:  #d4820a;
  --red:    #c83050;
  --violet: #6a50f0;
  --cyan:   #0fa8cc;
}

[data-theme="light"] body {
  background: var(--bg);
}

[data-theme="light"] #three-canvas {
  opacity: 0.18;
  filter: invert(1) hue-rotate(180deg);
}

[data-theme="light"] .nav-pill {
  background: rgba(240,240,248,.92);
  box-shadow: 0 4px 24px rgba(0,0,0,.12), 0 1px 0 rgba(255,255,255,.8) inset;
}

[data-theme="light"] .search-wrap input {
  background: rgba(240,240,248,.92);
  color: var(--t1);
}

[data-theme="light"] .icon-btn {
  background: rgba(240,240,248,.92);
}

[data-theme="light"] .icon-btn:hover {
  background: rgba(0,0,0,.06);
}

[data-theme="light"] .logout-btn {
  background: rgba(200,48,80,.06);
  border-color: rgba(200,48,80,.18);
}

[data-theme="light"] .logout-btn:hover {
  background: rgba(200,48,80,.14);
  border-color: rgba(200,48,80,.38);
}

[data-theme="light"] .card {
  background: rgba(255,255,255,.72);
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 0 1px var(--bd);
}

[data-theme="light"] .card:hover {
  background: rgba(255,255,255,.95);
}

[data-theme="light"] .fw-widget {
  background: rgba(255,255,255,.8);
}

[data-theme="light"] .dw-card {
  background: rgba(255,255,255,.75);
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 0 1px var(--bd);
}

[data-theme="light"] .notif-panel {
  background: rgba(248,248,252,.98);
  box-shadow: 0 20px 60px rgba(0,0,0,.18), 0 1px 0 rgba(255,255,255,.9) inset;
}

[data-theme="light"] .meteo-float {
  background: rgba(248,248,252,.92);
}

[data-theme="light"] .meteo-panel {
  background: rgba(248,248,252,.98);
  box-shadow: 0 20px 60px rgba(0,0,0,.18), 0 1px 0 rgba(255,255,255,.9) inset;
}

[data-theme="light"] .logo-sq {
  background: #18181e;
  color: #f0f0f5;
  box-shadow: 0 0 18px rgba(0,0,0,.18);
}

[data-theme="light"] .logo-name {
  color: var(--t1);
}

[data-theme="light"] .nav-avatar {
  border-color: rgba(0,0,0,.1);
}

[data-theme="light"] #cur-dot {
  background: #18181e;
}

[data-theme="light"] #cur-ring {
  border-color: rgba(24,24,30,.3);
}

[data-theme="light"] body:has(.card:hover) #cur-ring,
[data-theme="light"] body:has(a:hover) #cur-ring,
[data-theme="light"] body:has(button:hover) #cur-ring {
  border-color: rgba(24,24,30,.55);
}

[data-theme="light"] .hero-greeting em {
  color: #18181e;
}

/* Card accent overrides for light — keep colour pops but softer */
[data-theme="light"] .cc-blue:hover   { box-shadow: 0 16px 48px rgba(46,110,245,.14); }
[data-theme="light"] .cc-teal:hover   { box-shadow: 0 16px 48px rgba(15,173,126,.14); }
[data-theme="light"] .cc-amber:hover  { box-shadow: 0 16px 48px rgba(212,130,10,.14); }
[data-theme="light"] .cc-red:hover    { box-shadow: 0 16px 48px rgba(200,48,80,.14); }
[data-theme="light"] .cc-violet:hover { box-shadow: 0 16px 48px rgba(106,80,240,.14); }
[data-theme="light"] .cc-cyan:hover   { box-shadow: 0 16px 48px rgba(15,168,204,.14); }

/* ─── THEME TOGGLE BUTTON ─── */
.theme-btn {
  width: 34px; height: 34px; border-radius: 999px;
  background: rgba(12,12,18,.88);
  border: 1px solid var(--bd);
  backdrop-filter: blur(28px);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--t2); position: relative;
  transition: background .2s, color .2s, border-color .2s, transform .3s cubic-bezier(.34,1.56,.64,1);
  flex-shrink: 0;
  overflow: hidden;
}
.theme-btn:hover {
  background: rgba(255,255,255,.08);
  color: var(--t1);
  border-color: var(--bdh);
  transform: rotate(20deg) scale(1.07);
}

[data-theme="light"] .theme-btn {
  background: rgba(240,240,248,.92);
}
[data-theme="light"] .theme-btn:hover {
  background: rgba(0,0,0,.06);
  transform: rotate(-20deg) scale(1.07);
}

.theme-btn .icon-sun,
.theme-btn .icon-moon { position: absolute; transition: opacity .25s, transform .3s cubic-bezier(.22,1,.36,1); }

/* dark mode → show moon, hide sun */
.theme-btn .icon-sun  { opacity: 0; transform: rotate(90deg) scale(.7); }
.theme-btn .icon-moon { opacity: 1; transform: rotate(0deg) scale(1); }

/* light mode → show sun, hide moon */
[data-theme="light"] .theme-btn .icon-sun  { opacity: 1; transform: rotate(0deg) scale(1); }
[data-theme="light"] .theme-btn .icon-moon { opacity: 0; transform: rotate(-90deg) scale(.7); }

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--t1);
  font-family: 'Geist', system-ui, sans-serif;
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  transition: background .35s, color .25s;
}

/* ─── THREE.JS CANVAS ─── */
#three-canvas {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  transition: opacity .4s, filter .4s;
}

/* ─── NAVBAR ─── */
nav {
  position: sticky;
  top: 14px;
  z-index: 50;
  padding: 0 28px;
  background: none;
  border: none;
  transform: translateY(-120%);
  animation: navSlide .7s cubic-bezier(.22,1,.36,1) .1s forwards;
}

@keyframes navSlide { to { transform: translateY(0); } }

.nav-inner {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
}

/* Logo */
.nav-logo {
  display: flex; align-items: center; gap: 9px;
  text-decoration: none; flex-shrink: 0;
}
.logo-sq {
  width: 32px; height: 32px; border-radius: 9px;
  background: #ffffff;
  display: flex; align-items: center; justify-content: center; color: #06060a;
  box-shadow: 0 0 18px rgba(255,255,255,.22);
  transition: box-shadow .3s;
}
.nav-logo:hover .logo-sq { box-shadow: 0 0 32px rgba(255,255,255,.45); }
.logo-name { font-size: .92rem; font-weight: 700; letter-spacing: -.03em; color: var(--t1); }

/* Pill central */
.nav-pill {
  flex-shrink: 0;
  margin: 0 auto;
  background: rgba(12,12,18,.88);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border: 1px solid var(--bd);
  border-radius: 999px;
  padding: 5px 6px;
  display: flex; align-items: center; gap: 2px;
  box-shadow: 0 4px 32px rgba(0,0,0,.4), 0 1px 0 rgba(255,255,255,.05) inset;
}

.nav-link {
  display: flex; align-items: center; gap: 5px;
  padding: 6px 11px; border-radius: 999px;
  font-size: .8rem; font-weight: 500; color: var(--t2);
  text-decoration: none; cursor: pointer;
  transition: background .2s, color .2s;
  border: none; background: none; white-space: nowrap;
}
.nav-link:hover { background: rgba(255,255,255,.07); color: var(--t1); }
.nav-link.active { background: rgba(80,144,248,.15); color: var(--blue); }
.nav-link svg { flex-shrink: 0; }

[data-theme="light"] .nav-link:hover { background: rgba(0,0,0,.05); color: var(--t1); }
[data-theme="light"] .nav-link.active { background: rgba(46,110,245,.1); color: var(--blue); }

/* Direita */
.nav-right {
  display: flex; align-items: center; gap: 8px;
  flex-shrink: 0;
}

.search-wrap { position: relative; }
.search-wrap input {
  background: rgba(12,12,18,.88);
  border: 1px solid var(--bd);
  border-radius: 999px;
  padding: 8px 16px 8px 34px;
  font-size: .78rem; color: var(--t1); outline: none;
  font-family: 'Geist', sans-serif; width: 200px;
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  transition: border-color .25s, box-shadow .25s, width .35s cubic-bezier(.22,1,.36,1), background .3s;
}
.search-wrap input::placeholder { color: var(--t3); }
.search-wrap input:focus {
  border-color: rgba(80,144,248,.4);
  box-shadow: 0 0 0 3px rgba(80,144,248,.08);
  width: 250px;
}
.s-ico {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--t3); pointer-events: none;
}

.icon-btn {
  width: 34px; height: 34px; border-radius: 999px;
  background: rgba(12,12,18,.88);
  border: 1px solid var(--bd);
  backdrop-filter: blur(28px);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--t2); position: relative;
  transition: background .2s, color .2s, border-color .2s;
}
.icon-btn:hover { background: rgba(255,255,255,.08); color: var(--t1); border-color: var(--bdh); }
.pip {
  position: absolute; top: 6px; right: 6px;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--red); border: 1.5px solid var(--bg);
}

.nav-avatar {
  width: 34px; height: 34px; border-radius: 999px;
  background: linear-gradient(135deg, var(--blue), var(--violet));
  display: flex; align-items: center; justify-content: center;
  font-size: .65rem; font-weight: 700; color: #fff;
  overflow: hidden; flex-shrink: 0;
  border: 1.5px solid rgba(255,255,255,.1);
  cursor: default;
}
.nav-avatar img {
  width: 100%; height: 100%;
  object-fit: cover; border-radius: 999px;
  display: block;
}

.logout-btn {
  width: 34px; height: 34px; border-radius: 999px;
  background: rgba(224,92,110,.08);
  border: 1px solid rgba(224,92,110,.2);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--red);
  transition: background .2s, border-color .2s, transform .2s, box-shadow .2s;
  flex-shrink: 0;
}
.logout-btn:hover {
  background: rgba(224,92,110,.18);
  border-color: rgba(224,92,110,.45);
  transform: scale(1.07);
  box-shadow: 0 0 16px rgba(224,92,110,.2);
}

/* ─── PAGE ─── */
.page {
  position: relative; z-index: 1;
  max-width: 1080px; margin: 0 auto;
  padding: 52px 28px 80px;
}

/* ─── HERO ─── */
.hero { margin-bottom: 52px; }
.hero-greeting {
  font-size: 1.75rem; font-weight: 700; letter-spacing: -.04em;
  opacity: 0; transform: translateY(20px);
  animation: slideUp .7s cubic-bezier(.22,1,.36,1) .3s forwards;
}
.hero-greeting em { font-style: normal; color: #ffffff; }
.hero-sub {
  font-size: .75rem; color: var(--t3); font-family: 'Geist Mono', monospace;
  margin-top: 6px;
  opacity: 0; transform: translateY(14px);
  animation: slideUp .6s cubic-bezier(.22,1,.36,1) .45s forwards;
}

/* ─── SECTION ─── */
.section { margin-bottom: 40px; }
.section-label {
  font-size: .6rem; text-transform: uppercase; letter-spacing: .12em;
  color: var(--t3); font-family: 'Geist Mono', monospace;
  display: flex; align-items: center; gap: 8px; margin-bottom: 12px;
  opacity: 0; animation: slideUp .5s cubic-bezier(.22,1,.36,1) forwards;
}
.section-label::before {
  content: ''; width: 3px; height: 12px; border-radius: 2px; background: var(--blue);
}

/* ─── GRID ─── */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px,1fr)); gap: 10px; }
.grid-5 { grid-template-columns: repeat(5,1fr); }

/* ─── CARD ─── */
.card {
  background: rgba(14,14,20,.65);
  border: 1px solid var(--bd);
  border-radius: 14px; padding: 18px 16px 14px;
  display: flex; flex-direction: column; gap: 12px;
  text-decoration: none; color: inherit; cursor: pointer;
  position: relative; overflow: hidden;
  backdrop-filter: blur(12px);
  opacity: 0; transform: translateY(18px);
  transition:
    border-color .25s,
    transform .45s cubic-bezier(.22,1,.36,1),
    box-shadow .35s,
    background .25s;
  will-change: transform;
}
.card.visible { opacity: 1; transform: translateY(0); }

.card::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1.5px;
  border-radius: 14px 14px 0 0; opacity: 0;
  transition: opacity .3s cubic-bezier(.22,1,.36,1);
}
.card:hover { border-color: var(--bdh); }
.card:hover::after { opacity: 1; }

.card::before {
  content: ''; position: absolute; inset: 0; border-radius: 14px;
  opacity: 0; transition: opacity .35s; pointer-events: none;
}
.card:hover::before { opacity: 1; }

.cc-blue::after   { background: var(--blue); }
.cc-blue::before  { background: radial-gradient(ellipse 60% 50% at 30% 0%, rgba(80,144,248,.08), transparent); }
.cc-blue:hover    { box-shadow: 0 16px 48px rgba(80,144,248,.1); }

.cc-teal::after   { background: var(--teal); }
.cc-teal::before  { background: radial-gradient(ellipse 60% 50% at 30% 0%, rgba(45,212,160,.08), transparent); }
.cc-teal:hover    { box-shadow: 0 16px 48px rgba(45,212,160,.1); }

.cc-amber::after  { background: var(--amber); }
.cc-amber::before { background: radial-gradient(ellipse 60% 50% at 30% 0%, rgba(245,166,35,.08), transparent); }
.cc-amber:hover   { box-shadow: 0 16px 48px rgba(245,166,35,.1); }

.cc-red::after    { background: var(--red); }
.cc-red::before   { background: radial-gradient(ellipse 60% 50% at 30% 0%, rgba(224,92,110,.08), transparent); }
.cc-red:hover     { box-shadow: 0 16px 48px rgba(224,92,110,.1); }

.cc-violet::after  { background: var(--violet); }
.cc-violet::before { background: radial-gradient(ellipse 60% 50% at 30% 0%, rgba(144,128,250,.08), transparent); }
.cc-violet:hover   { box-shadow: 0 16px 48px rgba(144,128,250,.1); }

.cc-cyan::after    { background: var(--cyan); }
.cc-cyan::before   { background: radial-gradient(ellipse 60% 50% at 30% 0%, rgba(56,196,232,.08), transparent); }
.cc-cyan:hover     { box-shadow: 0 16px 48px rgba(56,196,232,.1); }

.card-head { display: flex; align-items: flex-start; justify-content: space-between; }
.c-icon {
  width: 38px; height: 38px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  transition: transform .3s cubic-bezier(.22,1,.36,1);
}
.card:hover .c-icon { transform: scale(1.08); }

.i-blue   { background: rgba(80,144,248,.13);  color: var(--blue); }
.i-teal   { background: rgba(45,212,160,.11);  color: var(--teal); }
.i-amber  { background: rgba(245,166,35,.11);  color: var(--amber); }
.i-red    { background: rgba(224,92,110,.11);  color: var(--red); }
.i-violet { background: rgba(144,128,250,.11); color: var(--violet); }
.i-cyan   { background: rgba(56,196,232,.11);  color: var(--cyan); }

.badge {
  font-size: .57rem; font-family: 'Geist Mono', monospace;
  letter-spacing: .05em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 999px; font-weight: 500;
}
.b-new  { background: rgba(80,144,248,.12);  color: var(--blue);   border: 1px solid rgba(80,144,248,.2); }
.b-soon { background: rgba(245,166,35,.1);   color: var(--amber);  border: 1px solid rgba(245,166,35,.2); }
.b-ext  { background: rgba(255,255,255,.04); color: var(--t3);     border: 1px solid var(--bd); }

[data-theme="light"] .b-ext {
  background: rgba(0,0,0,.04);
}

.ext-arrow {
  color: var(--t3); opacity: 0;
  transform: translate(-3px, 3px);
  transition: opacity .22s, transform .22s cubic-bezier(.22,1,.36,1);
}
.card:hover .ext-arrow { opacity: 1; transform: translate(0,0); }

.card-name { font-size: .87rem; font-weight: 600; letter-spacing: -.02em; color: var(--t1); }

.card-foot {
  display: flex; align-items: center; gap: 5px;
  padding-top: 8px; border-top: 1px solid var(--bd);
}
.dot { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }
.dot-on   { background: var(--teal); box-shadow: 0 0 5px rgba(45,212,160,.6); animation: blink 3s ease-in-out infinite; }
.dot-warn { background: var(--amber); }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.5} }
.foot-label { font-size: .64rem; color: var(--t3); font-family: 'Geist Mono', monospace; }

/* ─── KEYFRAMES ─── */
@keyframes slideUp { to { opacity: 1; transform: translateY(0); } }

/* ─── RESPONSIVE ─── */
@media (max-width: 860px) {
  nav { top: 8px; padding: 0 14px; }
  .logo-name { display: none; }
  .grid-5 { grid-template-columns: repeat(3,1fr); }
  .search-wrap input { width: 140px; }
}
@media (max-width: 560px) {
  .page { padding: 24px 14px 48px; }
  .grid-5 { grid-template-columns: repeat(2,1fr); }
  .search-wrap { display: none; }
}

/* ─── CUSTOM CURSOR ─── */
* { cursor: none !important; }
#cur-dot {
  position: fixed; top: 0; left: 0; z-index: 9999;
  width: 6px; height: 6px; border-radius: 50%;
  background: #ffffff;
  pointer-events: none;
  transform: translate(-50%, -50%);
  transition: opacity .2s, background .3s;
}
#cur-ring {
  position: fixed; top: 0; left: 0; z-index: 9998;
  width: 22px; height: 22px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.4);
  pointer-events: none;
  transform: translate(-50%, -50%);
  transition: width .25s, height .25s, opacity .2s, border-color .3s;
}
body:has(.card:hover) #cur-ring,
body:has(a:hover) #cur-ring,
body:has(button:hover) #cur-ring { width: 34px; height: 34px; border-color: rgba(255,255,255,.65); }

/* ─── AVATAR HOVER ─── */
.nav-avatar {
  position: relative;
  overflow: hidden;
}

.nav-avatar::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.55);
  opacity: 0;
  transition: opacity .22s cubic-bezier(.22,1,.36,1);
  z-index: 1;
}
.nav-avatar .avatar-cam {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .22s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
}

.nav-avatar:hover::after,
.nav-avatar:hover .avatar-cam {
  opacity: 1;
}

/* ─── RESPONSIVE FULL ─── */
@media (max-width: 900px) {
  nav { top: 8px; padding: 0 16px; }
  .logo-name { display: none; }
  .grid-5 { grid-template-columns: repeat(3, 1fr); }
  .search-wrap input { width: 140px; }
  .search-wrap input:focus { width: 170px; }
  .page { padding: 40px 20px 64px; }
}

@media (max-width: 700px) {
  .nav-pill { display: none; }
  .nav-right { gap: 6px; }
  .search-wrap input { width: 120px; }
  .search-wrap input:focus { width: 150px; }
  .hero-greeting { font-size: 1.4rem; }
  .grid { grid-template-columns: repeat(2, 1fr); }
  .grid-5 { grid-template-columns: repeat(2, 1fr); }
  .page { padding: 28px 16px 56px; }
}

@media (max-width: 480px) {
  nav { top: 6px; padding: 0 10px; }
  .search-wrap { display: none; }
  .icon-btn { width: 30px; height: 30px; }
  .nav-avatar { width: 30px; height: 30px; font-size: .6rem; }
  .logout-btn { width: 30px; height: 30px; }
  .theme-btn { width: 30px; height: 30px; }
  .logo-sq { width: 28px; height: 28px; border-radius: 8px; }
  .nav-right { gap: 5px; }
  .hero { margin-bottom: 32px; }
  .hero-greeting { font-size: 1.2rem; }
  .hero-sub { font-size: .7rem; }
  .page { padding: 20px 12px 48px; }
  .grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .grid-5 { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .card { padding: 14px 12px 10px; gap: 8px; border-radius: 12px; }
  .c-icon { width: 32px; height: 32px; border-radius: 8px; }
  .card-name { font-size: .8rem; }
  .foot-label { font-size: .6rem; }
  .badge { font-size: .52rem; padding: 2px 5px; }
  #cur-dot, #cur-ring { display: none; }
  * { cursor: auto !important; }
}

@media (max-width: 360px) {
  .grid { grid-template-columns: 1fr; }
  .grid-5 { grid-template-columns: 1fr; }
  .hero-greeting { font-size: 1.05rem; }
}

/* ─── NOTIFICAÇÕES ─── */
.notif-wrap { position: relative; }

.notif-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: 300px;
  background: rgba(10,10,16,.97);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border: 1px solid var(--bd);
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.65), 0 1px 0 rgba(255,255,255,.05) inset;
  z-index: 200;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-8px) scale(.97);
  pointer-events: none;
  transition: opacity .2s, transform .22s cubic-bezier(.22,1,.36,1), background .3s;
}
.notif-panel.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.notif-panel-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px 10px;
  border-bottom: 1px solid var(--bd);
}
.notif-panel-title { font-size: .78rem; font-weight: 600; color: var(--t1); }
.notif-clear-btn {
  font-size: .68rem; color: var(--t3);
  background: none; border: none; cursor: none;
  font-family: 'Geist', sans-serif;
  transition: color .2s;
}
.notif-clear-btn:hover { color: var(--t2); }

.notif-admin-row {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 16px;
  font-size: .72rem; color: var(--amber);
  background: rgba(245,166,35,.05);
  border-bottom: 1px solid var(--bd);
}
.notif-admin-row #notif-admin-pending { font-weight: 700; font-size: .85rem; }
.notif-admin-row a {
  color: var(--amber); text-decoration: none; opacity: .7;
  font-size: .68rem; transition: opacity .2s;
}
.notif-admin-row a:hover { opacity: 1; }

.notif-list {
  max-height: 280px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: var(--bd) transparent;
}
.notif-empty {
  padding: 24px 16px; font-size: .75rem;
  color: var(--t3); text-align: center;
}
.notif-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 11px 16px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  cursor: pointer;
  transition: background .18s;
}
.notif-item:hover { background: rgba(255,255,255,.04); }
.notif-item.n-read { opacity: .5; }
.notif-item:last-child { border-bottom: none; }

[data-theme="light"] .notif-item {
  border-bottom-color: rgba(0,0,0,.05);
}
[data-theme="light"] .notif-item:hover { background: rgba(0,0,0,.04); }

.notif-ico {
  width: 22px; height: 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .62rem; font-weight: 700; flex-shrink: 0; margin-top: 1px;
}
.n-ok   { background: rgba(45,212,160,.15); color: var(--teal); }
.n-err  { background: rgba(224,92,110,.15); color: var(--red);  }
.n-info { background: rgba(80,144,248,.15); color: var(--blue); }
.notif-body { flex: 1; min-width: 0; }
.notif-msg  { font-size: .74rem; color: var(--t1); line-height: 1.4; }
.notif-time { font-size: .63rem; color: var(--t3); margin-top: 3px; font-family: 'Geist Mono', monospace; }

/* ─── WIDGET FÉRIAS ─── */
.fw-widget {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: rgba(14,14,20,.75);
  border: 1px solid var(--bd);
  border-radius: 20px;
  padding: 13px 18px;
  max-width: 300px;
  margin-top: 28px;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  opacity: 0;
  transform: translateY(12px);
  animation: slideUp .6s cubic-bezier(.22,1,.36,1) .5s forwards;
  transition: border-color .25s, box-shadow .3s, background .3s;
}
.fw-widget:hover {
  border-color: var(--bdh);
  box-shadow: 0 12px 40px rgba(45,212,160,.08);
}

.fw-ring-wrap {
  position: relative;
  width: 58px;
  height: 58px;
  flex-shrink: 0;
}
.fw-ring-wrap svg { display: block; }

#fw-ring-fill {
  transition: stroke-dashoffset .9s cubic-bezier(.22,1,.36,1), stroke .4s;
}

.fw-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.fw-num {
  font-size: 17px;
  font-weight: 700;
  color: var(--t1);
  letter-spacing: -.03em;
  line-height: 1;
}
.fw-unit {
  font-size: 9px;
  color: var(--t3);
  letter-spacing: .04em;
  line-height: 1.4;
}

.fw-body { flex: 1; min-width: 0; }

.fw-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2px;
}
.fw-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--t1);
  letter-spacing: -.02em;
}
.fw-link {
  color: var(--t3);
  opacity: 0;
  display: flex;
  align-items: center;
  text-decoration: none;
  transition: opacity .2s, color .2s;
}
.fw-widget:hover .fw-link { opacity: 1; color: var(--teal); }

.fw-meta {
  font-size: 10px;
  color: var(--t3);
  font-family: 'Geist Mono', monospace;
  margin-bottom: 4px;
}

.fw-transicao {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 9.5px;
  font-weight: 600;
  color: #0284c7;
  background: rgba(2,132,199,.12);
  border: 1px solid rgba(2,132,199,.25);
  border-radius: 99px;
  padding: 1px 7px;
  margin-bottom: 6px;
}

.fw-bar-wrap {
  height: 3px;
  background: rgba(255,255,255,.07);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 8px;
}

[data-theme="light"] .fw-bar-wrap {
  background: rgba(0,0,0,.07);
}

.fw-bar-fill {
  height: 100%;
  border-radius: 99px;
  background: var(--teal);
  width: 0%;
  transition: width .9s cubic-bezier(.22,1,.36,1), background .4s;
}

.fw-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.fw-chip {
  font-size: 10px;
  color: var(--t2);
  background: rgba(255,255,255,.05);
  border: 1px solid var(--bd);
  border-radius: 99px;
  padding: 2px 8px;
  white-space: nowrap;
}

[data-theme="light"] .fw-chip {
  background: rgba(0,0,0,.04);
}

.fw-chip.fw-more {
  background: rgba(80,144,248,.1);
  border-color: rgba(80,144,248,.2);
  color: var(--blue);
}
.fw-loading, .fw-empty {
  font-size: 10px;
  color: var(--t3);
}

@media (max-width: 480px) {
  .fw-widget { max-width: 100%; }
}

/* ─── FLOATING WEATHER ─── */
.meteo-float {
  position: fixed;
  top: 58px;
  right: 20px;
  z-index: 45;
  display: flex;
  align-items: center;
  gap: 7px;
  background: rgba(10,10,16,.88);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border: 1px solid var(--bd);
  border-radius: 999px;
  padding: 7px 13px 7px 10px;
  opacity: 0;
  pointer-events: none;
  cursor: pointer;
  transition: opacity .3s, border-radius .3s cubic-bezier(.22,1,.36,1),
              padding .3s cubic-bezier(.22,1,.36,1), box-shadow .3s, border-color .2s, background .3s;
}
.meteo-float.loaded {
  opacity: 1;
  pointer-events: auto;
}
.meteo-float:hover {
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
  border-color: var(--bdh);
}
#mf-ico   { font-size: 1.1rem; line-height: 1; flex-shrink: 0; }
#mf-temp  { font-size: .82rem; font-weight: 700; color: var(--t1); flex-shrink: 0; }
.mf-detail {
  display: flex; flex-direction: column; gap: 1px;
  max-width: 0; overflow: hidden; opacity: 0;
  transition: max-width .3s cubic-bezier(.22,1,.36,1), opacity .25s;
  white-space: nowrap;
}
.meteo-float:hover .mf-detail { max-width: 140px; opacity: 1; }
#mf-desc { font-size: .7rem; color: var(--t2); }
#mf-loc  { font-size: .6rem; color: var(--t3); font-family: 'Geist Mono', monospace; }

/* ─── WEATHER PANEL ─── */
.meteo-panel {
  position: fixed;
  top: 102px;
  right: 20px;
  z-index: 44;
  width: 300px;
  background: rgba(10,10,16,.97);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border: 1px solid var(--bd);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.65), 0 1px 0 rgba(255,255,255,.05) inset;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-8px) scale(.97);
  pointer-events: none;
  transition: opacity .2s, transform .22s cubic-bezier(.22,1,.36,1), background .3s;
}
.meteo-panel.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.meteo-panel-head {
  padding: 14px 16px 12px;
  border-bottom: 1px solid var(--bd);
}
.meteo-panel-city {
  font-size: .72rem; font-weight: 600;
  color: var(--t2); font-family: 'Geist Mono', monospace;
  letter-spacing: .06em; text-transform: uppercase;
  margin-bottom: 10px;
}
.meteo-now {
  display: flex; align-items: center; gap: 10px;
}
.meteo-big-ico  { font-size: 2.2rem; line-height: 1; flex-shrink: 0; }
.meteo-big-temp {
  font-size: 2.6rem; font-weight: 700; color: var(--t1);
  letter-spacing: -.05em; line-height: 1; flex-shrink: 0;
}
.meteo-now-detail {
  display: flex; flex-direction: column; gap: 3px;
}
.meteo-now-detail span:first-child { font-size: .78rem; color: var(--t2); }
.meteo-now-detail span:last-child  { font-size: .62rem; color: var(--t3); font-family: 'Geist Mono', monospace; }

.meteo-days {
  max-height: 320px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--bd) transparent;
}
.meteo-day-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 16px;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
[data-theme="light"] .meteo-day-row { border-bottom-color: rgba(0,0,0,.05); }
.meteo-day-row:last-child { border-bottom: none; }
.meteo-day-name {
  font-size: .68rem; color: var(--t3);
  font-family: 'Geist Mono', monospace;
  width: 32px; flex-shrink: 0;
}
.meteo-day-ico  { font-size: 1rem; width: 20px; text-align: center; flex-shrink: 0; }
.meteo-day-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.meteo-day-date { font-size: .58rem; color: var(--t3); font-family: 'Geist Mono', monospace; }
.meteo-bar-wrap {
  height: 3px; background: rgba(255,255,255,.07);
  border-radius: 99px; overflow: hidden;
}
[data-theme="light"] .meteo-bar-wrap { background: rgba(0,0,0,.08); }
.meteo-bar-fill {
  height: 100%; border-radius: 99px;
  background: linear-gradient(90deg, var(--blue), var(--teal));
}
.meteo-day-range {
  font-size: .68rem; color: var(--t2);
  font-family: 'Geist Mono', monospace;
  width: 60px; text-align: right; flex-shrink: 0;
}
.meteo-day-range strong { color: var(--t1); font-weight: 600; }

.meteo-loading {
  padding: 20px 16px; font-size: .72rem;
  color: var(--t3); text-align: center;
}
.meteo-big-ico svg { width: 36px; height: 36px; }
#mf-ico svg { width: 15px; height: 15px; }
.meteo-day-ico svg { width: 15px; height: 15px; }

/* ─── DRAG WIDGETS ─── */
.drag-hint {
  color: var(--t3); font-size: .55rem;
  font-family: 'Geist Mono', monospace; letter-spacing: .04em;
}

.dw-grid {
  display: flex; gap: 12px; flex-wrap: wrap;
}

.dw-card {
  position: relative;
  background: rgba(14,14,20,.7);
  border: 1px solid var(--bd);
  border-radius: 16px; padding: 16px 18px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  width: 210px; flex-shrink: 0;
  opacity: 0; transform: translateY(16px);
  animation: slideUp .6s cubic-bezier(.22,1,.36,1) .5s forwards;
  transition: border-color .2s, box-shadow .25s, opacity .2s, transform .25s, background .3s;
  user-select: none;
}
.dw-card.dw-dragging,
.card.dw-dragging {
  opacity: .35; transform: scale(.96);
  border-color: rgba(80,144,248,.3);
}
.dw-card.dw-over,
.card.dw-over {
  border-color: rgba(80,144,248,.5);
  box-shadow: 0 0 0 2px rgba(80,144,248,.12), 0 8px 32px rgba(80,144,248,.08);
}

.dw-drag-handle {
  position: absolute; top: 9px; right: 11px;
  font-size: .85rem; color: var(--t3);
  opacity: 0; transition: opacity .18s;
  letter-spacing: 1px; line-height: 1;
}
.dw-card:hover .dw-drag-handle { opacity: 1; }

.dw-head {
  display: flex; align-items: center; gap: 8px; margin-bottom: 12px;
}
.dw-icon {
  width: 28px; height: 28px; border-radius: 7px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.dw-title { font-size: .75rem; font-weight: 600; color: var(--t1); flex: 1; letter-spacing: -.02em; }
.dw-loc   { font-size: .6rem; color: var(--t3); font-family: 'Geist Mono', monospace; }

.dw-meteo-main { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }
.dw-temp {
  font-size: 1.9rem; font-weight: 700; color: var(--t1);
  letter-spacing: -.05em; line-height: 1;
}
.dw-meteo-ico { font-size: 1.5rem; line-height: 1; }
.dw-meteo-desc { font-size: .68rem; color: var(--t2); }

.dw-agenda-list { display: flex; flex-direction: column; gap: 8px; }
.dw-agenda-item  { display: flex; align-items: center; gap: 8px; }
.dw-agenda-dot   { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.dot-aprov { background: var(--teal); box-shadow: 0 0 5px rgba(45,212,160,.5); }
.dot-pend  { background: var(--amber); }
.dw-agenda-info  { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.dw-agenda-date  { font-size: .7rem; color: var(--t1); }
.dw-agenda-state { font-size: .6rem; font-family: 'Geist Mono', monospace; }
.st-ok   { color: var(--teal); }
.st-pend { color: var(--amber); }
.dw-agenda-dias  { font-size: .62rem; color: var(--t3); font-family: 'Geist Mono', monospace; flex-shrink: 0; }

.dw-loading, .dw-empty { font-size: .7rem; color: var(--t3); }

@media (max-width: 600px) {
  .dw-card { width: 100%; }
}

/* ─── ADMIN PAGE ─── */
.adm-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px; margin-bottom: 28px; flex-wrap: wrap;
}
.adm-title { font-size: 22px; font-weight: 700; color: var(--t1); margin-bottom: 4px; }
.adm-sub   { font-size: 13px; color: var(--t2); }

.adm-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin-bottom: 24px;
}
.adm-stat-card {
  background: var(--s1); border: 1px solid var(--bd); border-radius: 14px;
  padding: 18px 20px; display: flex; flex-direction: column; gap: 4px;
  transition: border-color .2s;
}
.adm-stat-card:hover { border-color: var(--bdh); }
.adm-stat-num { font-size: 28px; font-weight: 700; color: var(--t1); line-height: 1; }
.adm-stat-lbl { font-size: 11px; color: var(--t2); font-weight: 500; }

.adm-toolbar {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 20px; flex-wrap: wrap;
}
.adm-search {
  flex: 1; min-width: 200px;
  display: flex; align-items: center; gap: 8px;
  background: var(--s1); border: 1px solid var(--bd);
  border-radius: 10px; padding: 0 12px; height: 38px;
  transition: border-color .15s;
}
.adm-search:focus-within { border-color: var(--teal); }
.adm-search svg { color: var(--t3); flex-shrink: 0; }
.adm-search input {
  border: none; background: transparent; font-size: 13px; color: var(--t1);
  font-family: inherit; outline: none; width: 100%;
}
.adm-search input::placeholder { color: var(--t3); }
.adm-filter-sel {
  background: var(--s1); border: 1px solid var(--bd);
  border-radius: 10px; padding: 0 12px; height: 38px;
  font-size: 12px; color: var(--t2); font-family: inherit;
  outline: none; cursor: pointer; transition: border-color .15s;
}
.adm-filter-sel:focus { border-color: var(--teal); }
.adm-filter-sel option { background: var(--s2); }
.adm-refresh-btn {
  width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0;
  background: var(--s1); border: 1px solid var(--bd);
  color: var(--t2); cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.adm-refresh-btn:hover { background: var(--s2); color: var(--t1); border-color: var(--bdh); }

/* Employee grid */
#adm-emp-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 10px;
}
.adm-emp-card {
  background: var(--s1); border: 1px solid var(--bd);
  border-radius: 14px; padding: 14px 16px;
  display: flex; align-items: center; gap: 12px;
  transition: border-color .2s, background .2s;
}
.adm-emp-card:hover { border-color: var(--bdh); background: var(--s2); }
.adm-emp-card.inactive { opacity: .75; }

.aec-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--s3); border: 1px solid var(--bd);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; color: var(--t2);
  flex-shrink: 0; overflow: hidden;
}
.aec-avatar img { width: 100%; height: 100%; object-fit: cover; }

.aec-info { flex: 1; min-width: 0; }
.aec-nome  { font-size: 13px; font-weight: 600; color: var(--t1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.aec-email { font-size: 11px; color: var(--t2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 4px; }
.aec-meta  { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.aec-role  {
  font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 5px;
}
.role-func  { background: rgba(80,144,248,.12); color: var(--blue); }
.role-chefe { background: rgba(144,128,250,.12); color: var(--violet); }
.role-admin { background: rgba(245,166,35,.12);  color: var(--amber); }
.role-super { background: rgba(224,92,110,.12);  color: var(--red); }

.aec-dept  { font-size: 10px; color: var(--t3); }

.aec-toggle {
  flex-shrink: 0; padding: 5px 12px; border-radius: 7px;
  font-size: 11px; font-weight: 600; cursor: pointer;
  font-family: inherit; border: 1.5px solid transparent;
  transition: all .15s; display: inline-flex; align-items: center; gap: 5px;
  background: transparent;
}
.aec-toggle.on  {
  color: #dc2626; border-color: #dc2626;
}
.aec-toggle.on:hover  { background: rgba(220,38,38,.08); }
.aec-toggle.off {
  color: #16a34a; border-color: #16a34a;
}
.aec-toggle.off:hover { background: rgba(22,163,74,.08); }

.aec-inactive-badge {
  font-size: 10px; font-weight: 700;
  background: #fef2f2; color: #dc2626;
  border: 1px solid #fecaca;
  padding: 2px 7px; border-radius: 99px;
  display: inline-flex; align-items: center; gap: 3px;
}

.adm-pg-loading, .adm-pg-empty, .adm-pg-error {
  grid-column: 1 / -1; text-align: center;
  padding: 48px 0; font-size: 13px;
}
.adm-pg-loading { color: var(--t3); }
.adm-pg-empty   { color: var(--t2); }
.adm-pg-error   { color: var(--red); }

@media (max-width: 600px) {
  .adm-stats { grid-template-columns: 1fr 1fr; }
  #adm-emp-list { grid-template-columns: 1fr; }
  .adm-toolbar { gap: 8px; }
  .adm-filter-sel { flex: 1; }
}

/* ─── ADMIN SECTION (legacy, kept for compat) ─── */
.admin-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}

.admin-action-card {
  background: var(--s1);
  border: 1px solid var(--bd);
  border-radius: 14px;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  text-decoration: none;
}
.admin-action-card:hover {
  border-color: var(--bdh);
  background: var(--s2);
}
.admin-action-card .aac-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.aac-icon.teal { background: rgba(45,212,160,.12); color: var(--teal); }
.admin-action-card .aac-body { flex: 1; }
.admin-action-card .aac-title {
  font-size: 13px; font-weight: 600; color: var(--t1); margin-bottom: 2px;
}
.admin-action-card .aac-sub { font-size: 11px; color: var(--t2); }
.admin-action-card .aac-arrow { color: var(--t3); flex-shrink: 0; }

/* ─── CRIAR USER MODAL ─── */
.cu-overlay {
  display: none;
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  align-items: center; justify-content: center;
  padding: 16px;
}
.cu-overlay.open { display: flex; }

.cu-modal {
  background: var(--s2);
  border: 1px solid var(--bdh);
  border-radius: 20px;
  padding: 28px;
  width: 100%;
  max-width: 460px;
  max-height: 92vh;
  overflow-y: auto;
  box-shadow: 0 32px 80px rgba(0,0,0,.6);
  animation: cuSlideIn .25s cubic-bezier(.22,1,.36,1);
}
@keyframes cuSlideIn {
  from { opacity: 0; transform: translateY(12px) scale(.97); }
  to   { opacity: 1; transform: none; }
}

.cu-modal-head { margin-bottom: 20px; }
.cu-modal-title {
  font-size: 15px; font-weight: 700; color: var(--t1); margin-bottom: 3px;
}
.cu-modal-sub { font-size: 11.5px; color: var(--t2); }

.cu-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.cu-form-group { display: flex; flex-direction: column; gap: 5px; }
.cu-form-group.full { grid-column: 1 / -1; }
.cu-form-group label {
  font-size: 10.5px; font-weight: 600; color: var(--t2);
  text-transform: uppercase; letter-spacing: .5px;
}
.cu-form-group input,
.cu-form-group select {
  background: var(--s3);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 9px 12px;
  font-size: 13px; color: var(--t1);
  font-family: inherit; outline: none;
  transition: border-color .15s;
  width: 100%;
}
.cu-form-group input:focus,
.cu-form-group select:focus { border-color: var(--teal); }
.cu-form-group select option { background: var(--s2); color: var(--t1); }

.cu-msg {
  margin-top: 14px;
  font-size: 12px;
  padding: 10px 14px;
  border-radius: 8px;
  display: none;
}
.cu-msg.ok  {
  display: block;
  background: rgba(45,212,160,.08);
  border: 1px solid rgba(45,212,160,.22);
  color: var(--teal);
}
.cu-msg.err {
  display: block;
  background: rgba(224,92,110,.08);
  border: 1px solid rgba(224,92,110,.22);
  color: var(--red);
}

.cu-actions {
  display: flex; gap: 10px;
  margin-top: 20px; justify-content: flex-end;
}
.cu-btn-cancel {
  padding: 9px 18px; border-radius: 8px;
  border: 1px solid var(--bd); background: transparent;
  color: var(--t2); font-size: 13px; font-weight: 500;
  cursor: pointer; font-family: inherit; transition: all .15s;
}
.cu-btn-cancel:hover { background: var(--s3); color: var(--t1); }
.cu-btn-submit {
  padding: 9px 20px; border-radius: 8px;
  border: none; background: var(--teal);
  color: #06060a; font-size: 13px; font-weight: 600;
  cursor: pointer; font-family: inherit; transition: opacity .15s;
}
.cu-btn-submit:hover { opacity: .88; }
.cu-btn-submit:disabled { opacity: .45; cursor: default; }

.confirm-icon {
  width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px; flex-shrink: 0;
}
.confirm-icon.danger { background: rgba(220,38,38,.12); color: #dc2626; }
.confirm-icon.success { background: rgba(22,163,74,.12); color: #16a34a; }
.cu-btn-danger {
  background: #dc2626; color: #fff; border: none;
  padding: 9px 22px; border-radius: 8px; font-size: 13px;
  font-weight: 600; cursor: pointer; font-family: inherit;
  transition: opacity .15s;
}
.cu-btn-danger:hover { opacity: .85; }

[data-theme="light"] .cu-modal { box-shadow: 0 24px 60px rgba(0,0,0,.18); }
[data-theme="light"] .cu-form-group input,
[data-theme="light"] .cu-form-group select { color: var(--t1); }

@media (max-width: 600px) {
  .cu-modal { padding: 20px; border-radius: 16px; }
  .cu-form-grid { grid-template-columns: 1fr; }
}