:root {
  --bg: #040408;
  --s1: #090910;
  --s2: #0d0d18;
  --s3: #13131f;
  --border: #1a1a28;
  --border2: #242438;
  --g1: #00e5ff;
  --g2: #bf5fff;
  --g3: #ff3d6e;
  --g4: #ffb800;
  --g5: #00ff8c;
  --text: #f0f0f8;
  /* Contraste AA+ sobre fundos escuros / glass */
  --muted: #a8b0c8;
  --muted2: #bcc4d8;
  --text-secondary: #cdd2e4;
  --text-tertiary: #9aa3b8;
  --selection-footer-h: 148px;
  --footer-pad-bottom: 64px;
  /* Barra de navegação mobile (sidebar horizontal fixa) */
  --app-mobile-rail-h: 64px;
  --footer-pad-top: 0px;
  --footer-pad-left: 0px;
  --footer-pad-right: 0px;
  --sidebar-w: 76px;
  /* Sidebar motion — smooth, no layout jank (transform + opacity) */
  --sidebar-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --sidebar-ease-in-out: cubic-bezier(0.45, 0, 0.55, 1);
  --sidebar-dur: 0.26s;
  --sidebar-dur-fast: 0.18s;
  /* Sombras discretas (níveis 1–3; ~5% da intensidade visual anterior) */
  --shadow-1: 0 1px 3px rgba(0, 0, 0, 0.06);
  --shadow-2: 0 2px 8px rgba(0, 0, 0, 0.08);
  --shadow-3: 0 3px 14px rgba(0, 0, 0, 0.1);
  --font-heading: 'Satoshi', 'Poppins', system-ui, sans-serif;
  --font-body: 'Open Sans', 'Fira Sans', system-ui, sans-serif;
  --font-ui: 'Fira Sans', 'Open Sans', system-ui, sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}

html{scroll-behavior:smooth}

body.app-modal-open,
body.proj-preview-open{
  overflow:hidden;
}

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  min-height:100vh;
  overflow-x:hidden;
  padding-bottom:var(--footer-pad-bottom);
  padding-top:var(--footer-pad-top);
  padding-left:var(--footer-pad-left);
  padding-right:var(--footer-pad-right);
}

/* noise overlay */
body::after{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events:none;z-index:0;opacity:.4;
}

/* animated gradient bg */
body::before{
  content:'';
  position:fixed;inset:0;
  background:
    radial-gradient(ellipse 65% 45% at 15% -5%, rgba(0,229,255,0.045) 0%, transparent 55%),
    radial-gradient(ellipse 55% 40% at 88% 108%, rgba(0,255,140,0.035) 0%, transparent 55%),
    radial-gradient(ellipse 40% 30% at 50% 50%, rgba(191,95,255,0.02) 0%, transparent 60%);
  pointer-events:none;z-index:0;
}

/* ===== APP SHELL (sidebar + main) ===== */
.app-shell{
  display:flex;
  min-height:100vh;
  position:relative;
  z-index:1;
  align-items:stretch;
}
.app-sidebar{
  width:var(--sidebar-w);
  min-width:var(--sidebar-w);
  max-width:min(280px,92vw);
  flex-shrink:0;
  position:sticky;
  top:0;
  align-self:flex-start;
  height:100vh;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  padding:12px 0 14px;
  gap:6px;
  border-right:1px solid var(--border);
  background:rgba(8,8,14,0.55);
  backdrop-filter:blur(22px) saturate(1.2);
  -webkit-backdrop-filter:blur(22px) saturate(1.2);
  z-index:200;
  overflow-x:hidden;
  transition:
    width var(--sidebar-dur) var(--sidebar-ease-out),
    min-width var(--sidebar-dur) var(--sidebar-ease-out),
    border-color var(--sidebar-dur) var(--sidebar-ease-in-out),
    box-shadow var(--sidebar-dur) var(--sidebar-ease-out),
    padding var(--sidebar-dur) var(--sidebar-ease-out),
    gap var(--sidebar-dur) var(--sidebar-ease-out);
}
.app-sidebar.is-rail-expanded{
  align-items:stretch;
  padding-left:10px;
  padding-right:10px;
}
.app-sidebar.is-rail-collapsed{
  align-items:center;
  padding-left:0;
  padding-right:0;
}
.sidebar-slide-toggle{
  flex-shrink:0;
  align-self:center;
  width:40px;
  height:32px;
  margin:0 auto 0;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  border:1px solid var(--border);
  background:rgba(255,255,255,0.05);
  color:var(--text-tertiary);
  cursor:pointer;
  transform:translateZ(0);
  transition:
    transform var(--sidebar-dur-fast) var(--sidebar-ease-out),
    width var(--sidebar-dur) var(--sidebar-ease-out),
    margin var(--sidebar-dur) var(--sidebar-ease-out),
    border-color var(--sidebar-dur) var(--sidebar-ease-in-out),
    background-color var(--sidebar-dur) var(--sidebar-ease-in-out),
    color var(--sidebar-dur) var(--sidebar-ease-in-out),
    box-shadow var(--sidebar-dur) var(--sidebar-ease-out);
}
.sidebar-slide-toggle:hover{
  color:var(--text-tertiary);
  background:rgba(255,255,255,0.05);
  border-color:var(--border);
  transform:none;
  box-shadow:none;
}
.sidebar-slide-toggle:active{
  transform:scale(0.96) translateZ(0);
  transition-duration:0.08s;
}
.sidebar-slide-toggle .material-symbols-outlined{
  font-size:20px;
  display:block;
  transform-origin:50% 50%;
  transition:transform 0.45s var(--sidebar-ease-out);
}
.app-sidebar.is-rail-expanded .sidebar-slide-toggle .material-symbols-outlined{
  transform:rotate(180deg);
}
.sidebar-slide-toggle:hover .material-symbols-outlined{
  transform:none;
}
.app-sidebar.is-rail-expanded .sidebar-slide-toggle:hover .material-symbols-outlined{
  transform:rotate(180deg);
}
.app-sidebar.is-rail-expanded .sidebar-slide-toggle{
  align-self:stretch;
  width:auto;
  margin:0 6px 2px;
}
.sidebar-item-label{
  display:none;
  font-family:var(--font-ui);
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.02em;
  color:var(--text-tertiary);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  flex:1;
  min-width:0;
  text-align:left;
  transition:color var(--sidebar-dur) var(--sidebar-ease-in-out);
}
.app-sidebar.is-rail-expanded .sidebar-item-label{
  display:block;
}
.app-sidebar.is-rail-expanded .sidebar-item.tab-btn.active .sidebar-item-label{
  color:var(--text-secondary);
}
.app-main{
  flex:1;
  min-width:0;
  min-height:100vh;
}
.sidebar-nav{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  flex:1;
  width:100%;
  min-height:0;
  padding:4px 0 6px;
  overflow-y:auto;
  overflow-x:hidden;
  scrollbar-width:thin;
  transition:gap var(--sidebar-dur) var(--sidebar-ease-out),
    padding var(--sidebar-dur) var(--sidebar-ease-out);
}
.app-sidebar.is-rail-expanded .sidebar-nav{
  align-items:stretch;
  padding-left:2px;
  padding-right:2px;
}
.sidebar-spacer{flex:0 0 6px}
.sidebar-item.tab-btn,
button.sidebar-item{
  width:36px;
  height:36px;
  padding:0;
  border-radius:12px;
  border:1px solid transparent;
  background:transparent;
  color:var(--text-tertiary);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0;
  box-shadow:0 0 0 0 transparent;
  transform:translateZ(0);
  transition:
    width var(--sidebar-dur) var(--sidebar-ease-out),
    height var(--sidebar-dur) var(--sidebar-ease-out),
    padding var(--sidebar-dur) var(--sidebar-ease-out),
    gap var(--sidebar-dur) var(--sidebar-ease-out),
    transform var(--sidebar-dur-fast) var(--sidebar-ease-out),
    color var(--sidebar-dur) var(--sidebar-ease-in-out),
    background-color var(--sidebar-dur) var(--sidebar-ease-in-out),
    border-color var(--sidebar-dur) var(--sidebar-ease-in-out),
    box-shadow var(--sidebar-dur) var(--sidebar-ease-out);
}
.app-sidebar.is-rail-expanded .sidebar-item.tab-btn,
.app-sidebar.is-rail-expanded button.sidebar-item{
  width:100%;
  min-height:32px;
  height:auto;
  min-width:0;
  justify-content:flex-start;
  gap:6px;
  padding:6px 8px;
}
.sidebar-item .material-symbols-outlined{
  font-size:17px;
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;
  transform:translateZ(0);
  transition:transform var(--sidebar-dur-fast) var(--sidebar-ease-out);
}
.sidebar-item.tab-btn:hover,
button.sidebar-item:hover{
  color:var(--text-tertiary);
  background:transparent;
  transform:none;
  box-shadow:none;
}
.sidebar-item.tab-btn:hover .material-symbols-outlined,
button.sidebar-item:hover .material-symbols-outlined{
  transform:none;
}
.sidebar-item.tab-btn:active,
button.sidebar-item:active{
  transform:translateY(0) scale(0.96) translateZ(0);
  transition-duration:0.08s;
}
.sidebar-item.tab-btn.active{
  color:var(--text);
  background:rgba(0,229,255,0.08);
  border-color:rgba(0,229,255,0.32);
  box-shadow:var(--shadow-1);
}
.sidebar-item.tab-btn.active .material-symbols-outlined{
  transform:none;
}
.sidebar-item.tab-btn.active:hover,
button.sidebar-item.active:hover{
  transform:none;
  box-shadow:var(--shadow-1);
}
.sidebar-item.tab-btn:focus-visible,
button.sidebar-item:focus-visible,
.header-theme-switch-wrap .switch:focus-within,
.sidebar-slide-toggle:focus-visible{
  outline:2px solid var(--g2);
  outline-offset:2px;
}

@media (prefers-reduced-motion:reduce){
  .app-sidebar,
  .app-sidebar .sidebar-nav,
  .app-sidebar .sidebar-item.tab-btn,
  .app-sidebar button.sidebar-item,
  .app-sidebar .sidebar-item .material-symbols-outlined,
  .app-sidebar .sidebar-slide-toggle,
  .header-theme-switch-wrap .slider,
  .header-theme-switch-wrap .slider::before{
    transition-duration:0.01ms !important;
    transition-delay:0s !important;
  }
  .app-sidebar .sidebar-item.tab-btn:hover,
  .app-sidebar button.sidebar-item:hover,
  .app-sidebar .sidebar-slide-toggle:hover{
    transform:none;
    box-shadow:0 0 0 0 transparent;
  }
  .app-sidebar .sidebar-item:hover .material-symbols-outlined,
  .app-sidebar .sidebar-slide-toggle .material-symbols-outlined{
    transition-duration:0.01ms !important;
  }
  .app-sidebar:not(.is-rail-expanded) .sidebar-slide-toggle:hover .material-symbols-outlined{
    transform:none;
  }
  .app-sidebar.is-rail-expanded .sidebar-slide-toggle .material-symbols-outlined,
  .app-sidebar.is-rail-expanded .sidebar-slide-toggle:hover .material-symbols-outlined{
    transform:rotate(180deg);
  }
}

.wrap{max-width:1200px;margin:0 auto;padding:40px 24px 48px;position:relative;z-index:1}

/* ===== Cabeçalho da área principal (só eyebrow) ===== */
.app-page-header{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:12px 20px;
  padding:14px 24px 12px;
  position:relative;
  z-index:1;
  border-bottom:1px solid var(--border);
  background:rgba(5,5,8,0.35);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.header-theme-bar{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}
.header-theme-mark{
  font-size:20px;
  color:var(--g1);
  line-height:1;
  font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;
}
.header-theme-name{
  font-family:'DM Mono',monospace;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--text-tertiary);
  min-width:3.25em;
  text-align:right;
}
/* Switch de tema (estrutura tipo checkbox-wrapper-63 + paleta Ultra) */
.checkbox-wrapper-63.header-theme-switch-wrap *,
.checkbox-wrapper-63.header-theme-switch-wrap *::before,
.checkbox-wrapper-63.header-theme-switch-wrap *::after{
  box-sizing:border-box;
}
.header-theme-switch-wrap input[type="checkbox"]{
  position:absolute;
  opacity:0;
  width:100%;
  height:100%;
  margin:0;
  inset:0;
  cursor:pointer;
  z-index:2;
}
.header-theme-switch-wrap .switch{
  font-size:1rem;
  position:relative;
  display:inline-block;
  width:3.35em;
  height:1.85em;
}
.header-theme-switch-wrap .slider{
  position:absolute;
  cursor:pointer;
  inset:0;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--border2);
  border-radius:999px;
  transition:background 0.35s ease,border-color 0.35s ease;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.06);
  pointer-events:none;
}
.header-theme-switch-wrap .slider::before{
  position:absolute;
  content:"";
  width:1.35em;
  height:1.35em;
  border-radius:50%;
  left:0.22em;
  top:50%;
  transform:translateY(-50%);
  background:linear-gradient(145deg,var(--g1),#00b8cc);
  transition:transform 0.35s cubic-bezier(0.22,1,0.36,1),background 0.35s ease,box-shadow 0.35s ease;
  box-shadow:
    0 0 0 1px rgba(0,229,255,0.35),
    0 2px 8px rgba(0,0,0,0.35);
}
.header-theme-switch-wrap input:checked + .slider{
  background:rgba(191,95,255,0.1);
  border-color:rgba(191,95,255,0.32);
}
.header-theme-switch-wrap input:checked + .slider::before{
  transform:translateY(-50%) translateX(calc(3.35em - 1.35em - 0.44em));
  background:linear-gradient(145deg,var(--g2),#9d4edd);
  box-shadow:
    0 0 0 1px rgba(191,95,255,0.45),
    0 2px 8px rgba(0,0,0,0.35);
}
.header-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border2);
  border-radius:30px;
  padding:6px 16px;
  font-family:'DM Mono',monospace;
  font-size:11px;letter-spacing:2px;
  color:var(--text-tertiary);
  text-transform:uppercase;
  margin:0;
}
.header-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--g5);
  box-shadow:0 0 8px var(--g5);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* Navegação por tabs: barra horizontal removida — usar .app-sidebar .sidebar-item.tab-btn */

/* ===== TAB PANELS ===== */
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ===== SECTION HEADER ===== */
.sec-head{
  display:flex;align-items:center;gap:12px;
  margin-bottom:20px;
}
.sec-num{
  font-family:'DM Mono',monospace;
  font-size:10px;
  color:#7ee8ff;
  color:color-mix(in srgb, var(--g1) 88%, var(--text));
  letter-spacing:2px;
  opacity:1;
}
.sec-title{
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--text-secondary);
  font-family:'DM Mono',monospace;
}
.sec-line{flex:1;height:1px;background:var(--border)}

/* ===== CARDS (glassmorphism) ===== */
.card{
  background:rgba(13,13,22,0.42);
  backdrop-filter:blur(18px) saturate(1.25);
  -webkit-backdrop-filter:blur(18px) saturate(1.25);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;
  padding:28px;
  margin-bottom:24px;
  position:relative;
  transition:border-color .3s, box-shadow .3s;
  box-shadow:var(--shadow-2), inset 0 1px 0 rgba(255,255,255,0.04);
}
.card:hover{
  border-color:rgba(255,255,255,0.08);
  box-shadow:var(--shadow-2), inset 0 1px 0 rgba(255,255,255,0.04);
}
.card-glow::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--g1),var(--g2),transparent);
  border-radius:18px 18px 0 0;
  opacity:.5;
}

/* ===== PROJECT TYPE GRID ===== */
.proj-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(130px,1fr));
  gap:10px;
}

.proj-card{
  background:rgba(19,19,30,0.55);
  backdrop-filter:blur(10px) saturate(1.1);
  -webkit-backdrop-filter:blur(10px) saturate(1.1);
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px 10px;
  cursor:pointer;
  text-align:center;
  transition:border-color .2s ease, box-shadow .25s ease, background .2s ease;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.proj-card:hover:not(.active),
.proj-card:focus-within:not(.active){
  border-color:var(--border2);
  box-shadow:0 10px 32px rgba(0,0,0,0.28);
}
.proj-card.active{
  border-color:var(--g1);
  background:rgba(0,229,255,0.08);
  box-shadow:var(--shadow-1);
}
.proj-card.active:hover,
.proj-card.active:focus-within{
  border-color:var(--g1);
  box-shadow:var(--shadow-1), 0 0 0 1px rgba(0,229,255,0.12);
}
.proj-card:focus-visible{
  outline:2px solid var(--g1);
  outline-offset:2px;
}
/* Variante A: máscara + camada “flyer” (bottom-right) por trás do ícone */
.proj-card-icon-slot{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  flex-shrink:0;
}
.proj-card-mask{
  position:absolute;
  inset:2px;
  border-radius:14px;
  overflow:hidden;
  pointer-events:none;
  z-index:0;
}
.proj-card-flyer{
  position:absolute;
  right:-38%;
  bottom:-38%;
  width:150%;
  height:150%;
  background:linear-gradient(128deg,rgba(191,95,255,0.55) 0%,rgba(0,229,255,0.42) 40%,transparent 70%);
  transform:translate(26%,26%) rotate(-12deg);
  transform-origin:bottom right;
  opacity:0.38;
  transition:transform .45s cubic-bezier(.22,1,.36,1), opacity .32s ease;
}
.proj-card:hover .proj-card-flyer,
.proj-card:focus-within .proj-card-flyer{
  transform:translate(0,0) rotate(0deg);
  opacity:0.9;
}
.proj-card .proj-card-icon-slot .picon{
  position:relative;
  z-index:1;
}
@media (prefers-reduced-motion: reduce){
  .proj-card-flyer{
    transform:none;
    opacity:0.35;
    transition:opacity .2s ease;
  }
  .proj-card:hover .proj-card-flyer,
  .proj-card:focus-within .proj-card-flyer{
    opacity:0.82;
  }
}
.proj-card .pname{font-size:0.78rem;font-weight:700;color:var(--text)}
.proj-card .pcomplexity{
  font-family:'DM Mono',monospace;
  font-size:9px;letter-spacing:1px;
  text-transform:uppercase;
  padding:2px 8px;border-radius:10px;
}
.pcomplexity.low{
  background:rgba(6,78,59,0.45);
  border:1px solid rgba(52,211,153,0.35);
  color:#6ee7b7;
}
.pcomplexity.med{
  background:rgba(55,48,26,0.55);
  border:1px solid rgba(234,179,8,0.38);
  color:#fde68a;
}
.pcomplexity.high{
  background:rgba(76,5,25,0.55);
  border:1px solid rgba(251,113,133,0.42);
  color:#fecdd3;
}
.pcomplexity.ultra{
  background:rgba(46,16,101,0.5);
  border:1px solid rgba(196,181,253,0.38);
  color:#ddd6fe;
}

/* ===== DEV SEARCH (tab Sites) ===== */
.dev-search-card{margin-bottom:18px}
.dev-search-hint,.sites-tab-intro{
  font-size:0.82rem;
  color:var(--muted);
  margin:0 0 16px;
  line-height:1.55;
}
.dev-search-form{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-bottom:8px;
}
.dev-search-input{
  flex:1;
  min-width:200px;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid var(--border2);
  background:var(--s1);
  color:var(--text);
  font-family:'Poppins',sans-serif;
  font-size:0.88rem;
}
.dev-search-input:focus{
  outline:none;
  border-color:var(--g2);
  box-shadow:0 0 0 2px rgba(191,95,255,0.12);
}
.dev-search-select{
  padding:11px 12px;
  border-radius:10px;
  border:1px solid var(--border2);
  background:var(--s2);
  color:var(--text);
  font-family:'Poppins',sans-serif;
  font-size:0.82rem;
  cursor:pointer;
}
.dev-search-status{
  font-size:0.78rem;
  color:var(--g5);
  min-height:1.2em;
  margin-bottom:10px;
}
.dev-search-results{
  margin-top:12px;
  padding:14px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--s1);
}
.dev-search-opened,.dev-gh-hint,.dev-search-empty{
  font-size:0.82rem;
  color:var(--muted2);
  margin-bottom:12px;
  line-height:1.5;
}
.dev-search-error{color:var(--g3);font-size:0.85rem}
.dev-quick-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.dev-quick-links a{text-decoration:none}
.dev-gh-list{display:flex;flex-direction:column;gap:8px}
.dev-gh-row{
  display:flex;
  align-items:center;
  gap:12px;
  width:100%;
  text-align:left;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid var(--border2);
  background:var(--s2);
  color:var(--text);
  cursor:pointer;
  font-family:'Poppins',sans-serif;
  transition:border-color .2s,background .2s;
}
.dev-gh-row:hover{border-color:var(--g2);background:var(--s3)}
.dev-gh-row img{border-radius:50%;object-fit:cover;flex-shrink:0}
.dev-gh-meta{display:flex;flex-direction:column;gap:2px}
.dev-gh-meta strong{font-size:0.88rem}
.dev-gh-meta span{font-size:0.72rem;color:var(--muted)}
.dev-profile-detail{
  margin-top:14px;
  padding:16px;
  border-radius:12px;
  border:1px solid var(--g2);
  background:rgba(191,95,255,0.06);
}
.dev-profile-detail-head{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  margin-bottom:12px;
  font-size:0.95rem;
}
.dev-detail-grid{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start}
.dev-detail-avatar{border-radius:12px}
.dev-detail-line{margin:0 0 8px;font-size:0.86rem;line-height:1.45}
.dev-detail-line a{color:var(--g1)}
.dev-repos-wrap{margin-top:14px;padding-top:12px;border-top:1px dashed var(--border2)}
.dev-repos-title{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:8px}
.dev-repos{margin:0;padding-left:1.1rem;font-size:0.8rem;line-height:1.5;color:var(--muted2)}
.dev-repos li{margin-bottom:6px}
.dev-profile-detail-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.dev-paste-box{margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}
.dev-paste-label{display:block;font-size:0.78rem;font-weight:600;color:var(--muted);margin-bottom:8px}
.dev-paste-textarea{
  width:100%;
  margin-bottom:10px;
  padding:12px;
  border-radius:10px;
  border:1px solid var(--border2);
  background:var(--s1);
  color:var(--text);
  font-family:'Poppins',sans-serif;
  font-size:0.85rem;
  resize:vertical;
  min-height:100px;
}
.dev-notes-preview{font-size:0.78rem;color:var(--g5);margin:10px 0 8px}
.dev-clear-btn{margin-top:4px}
.muted{color:var(--muted)}

/* ===== FAMOUS SITES ===== */
.sites-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:12px;
}

.site-card{
  background:var(--s2);
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px;
  cursor:pointer;
  transition:all .2s;
  position:relative;
  overflow:hidden;
}
.site-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.site-card.active{border-color:var(--g2);background:rgba(191,95,255,0.06)}
.site-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:2px;
  opacity:0;transition:opacity .2s;
}
.site-card.active::before,.site-card:hover::before{opacity:1}

.site-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.site-emoji{flex-shrink:0;line-height:1;display:inline-flex;align-items:center;justify-content:center}
.site-name{font-weight:800;font-size:0.9rem}
.site-category{
  font-family:'DM Mono',monospace;
  font-size:9px;letter-spacing:1px;
  text-transform:uppercase;
  color:var(--muted);
}
.site-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.site-tag{
  font-family:'DM Mono',monospace;
  font-size:9px;
  padding:2px 7px;border-radius:4px;
  background:var(--s3);
  color:var(--muted2);
  border:1px solid var(--border);
  transition:all .2s;
}
.site-tag:hover{border-color:var(--g2);color:var(--text)}
.site-tags.expanded .site-tag{opacity:1;transform:none}
.site-tags.collapse .site-tag.hidden{display:none}
.founder-stack.expanded .fstack-tag{opacity:1}
.innov-companies.expanded .innov-co{opacity:1}
.fs-cat-list > .fs-item{
  display:flex;
  align-items:center;
  gap:6px;
  list-style:none;
}
.fs-cat-list.collapse .fs-item.hidden{display:none !important}
/* Disclosure: expandir listas (Sites, Fundadores, Inovações, Fullstack) */
.more-btn{
  font-family:'DM Mono',monospace;
  font-size:9px;
  font-weight:600;
  letter-spacing:0.04em;
  min-height:28px;
  padding:4px 12px 4px 8px;
  border-radius:999px;
  background:rgba(191,95,255,0.12);
  color:var(--g2);
  border:1px solid rgba(191,95,255,0.38);
  cursor:pointer;
  user-select:none;
  position:relative;
  z-index:2;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:6px;
  align-self:flex-start;
  transition:
    background .2s ease,
    border-color .2s ease,
    color .2s ease,
    box-shadow .2s ease;
}
.more-btn__inner{
  display:inline-flex;
  align-items:center;
  gap:4px;
}
.more-btn__chev{
  font-size:16px;
  width:1em;
  height:1em;
  line-height:1;
  flex-shrink:0;
  font-variation-settings:'FILL' 0,'wght' 500,'GRAD' 0,'opsz' 20;
  transition:transform .22s cubic-bezier(0.22,1,0.36,1);
}
.more-btn.is-expanded .more-btn__chev{
  transform:rotate(180deg);
}
.more-btn:hover{
  background:rgba(191,95,255,0.2);
  border-color:rgba(191,95,255,0.55);
  color:var(--text-secondary);
  box-shadow:0 1px 0 rgba(255,255,255,0.04);
}
.more-btn:active{
  transform:translateY(0);
  background:rgba(191,95,255,0.16);
}
.more-btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px var(--bg),0 0 0 4px rgba(0,229,255,0.45);
}
.more-btn.fs-more-btn{
  font-size:10px;
  min-height:30px;
  padding:5px 14px 5px 9px;
  margin-top:10px;
}
.founder-stack .more-btn{
  margin-top:6px;
}
.innov-companies .more-btn{
  margin-top:6px;
  font-size:8px;
  min-height:26px;
  padding:3px 10px 3px 6px;
}
.innov-companies .more-btn .more-btn__chev{
  font-size:14px;
}

.site-founders{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid var(--border);
}
.founders-label{
  font-size:9px;
  font-family:'DM Mono',monospace;
  letter-spacing:1px;
  color:var(--muted);
  text-transform:uppercase;
  margin-bottom:6px;
}
.founders-list{
  display:flex;flex-direction:column;gap:3px;
}
.founder-item{
  font-size:0.75rem;
  color:var(--muted2);
}
.founder-item strong{color:var(--text);font-size:0.78rem}

/* ===== TECH SELECTOR ===== */
.tech-mega{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:14px;
}

.tech-group{
  background:var(--s2);
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px;
}
.tech-group-title{
  font-family:'DM Mono',monospace;
  font-size:9px;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:12px;
  padding-bottom:8px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:6px;
}
.tech-tags{display:flex;flex-wrap:wrap;gap:5px}

.ttag{
  font-family:'DM Mono',monospace;
  font-size:10px;
  padding:3px 9px;
  border-radius:5px;
  border:1px solid var(--border);
  background:var(--s1);
  color:var(--muted);
  cursor:pointer;
  transition:all .15s;
  user-select:none;
}
.ttag:hover{border-color:var(--g2);color:var(--text)}
/* .ttag.new — mesmo visual base que .ttag; só o badge "NEW" distingue (não parecer já selecionado) */
.ttag.new::after{
  content:'NEW';
  font-size:7px;
  background:var(--g1);
  color:#000;
  border-radius:3px;
  padding:1px 4px;
  margin-left:5px;
  font-weight:700;
}
.ttag.new:hover::after{
  filter:brightness(1.08);
}
/* selecionado (clique ou sugestão automática) — aplica também a .ttag.new */
.ttag.sel{
  background:rgba(191,95,255,0.12);
  border-color:var(--g2);
  color:#fff;
}
.ttag.new.sel::after{
  background:var(--g2);
  color:#fff;
}

/* ===== COMPLEXITY SLIDER ===== */
.complexity-row{
  display:flex;align-items:center;gap:16px;
  flex-wrap:wrap;
}
.complexity-labels{
  display:flex;gap:0;
  background:var(--s2);
  border:1px solid var(--border);
  border-radius:10px;
  overflow:hidden;
  max-width:100%;
}
.clabel{
  padding:8px 16px;
  font-size:0.78rem;
  font-weight:700;
  cursor:pointer;
  border:none;
  background:transparent;
  color:var(--muted);
  font-family:var(--font-ui);
  transition:all .2s;
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex-shrink:0;
  white-space:nowrap;
}
.clabel.active{background:var(--s3);color:var(--text)}

/* ===== API KEY (Anthropic) ===== */
.api-key-intro{
  font-size:0.85rem;
  color:var(--muted);
  margin:0 0 12px;
  line-height:1.5;
}
.api-key-intro a{color:var(--g2);text-decoration:underline}
.file-protocol-banner{
  font-size:0.82rem;
  color:var(--text);
  margin:0 0 14px;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid rgba(255,180,0,0.45);
  background:rgba(255,180,0,0.12);
  line-height:1.55;
}
.file-protocol-banner code{
  font-family:'DM Mono',monospace;
  font-size:0.78rem;
  padding:2px 6px;
  border-radius:4px;
  background:rgba(0,0,0,0.25);
  word-break:break-all;
}
.api-key-box{
  margin-bottom:20px;
  padding:14px 16px;
  border-radius:12px;
  border:1px solid var(--border2);
  background:rgba(0,0,0,0.2);
}
.api-key-label{
  display:block;
  font-size:0.78rem;
  font-weight:700;
  color:var(--muted);
  margin-bottom:8px;
}
.api-key-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.api-key-input{
  flex:1;
  min-width:220px;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid var(--border2);
  background:var(--s1);
  color:var(--text);
  font-family:'DM Mono',monospace;
  font-size:0.82rem;
}
.api-key-input:focus{
  outline:none;
  border-color:var(--g2);
  box-shadow:0 0 0 2px rgba(0,229,255,0.15);
}
.api-key-status{
  margin:10px 0 0;
  font-size:0.78rem;
  color:var(--g3);
}
.api-key-status.key-ok{color:var(--g5)}
.api-key-status.key-missing{color:var(--g4)}

/* ===== MULTI-MODEL AI ===== */
.model-selector-wrap{margin-bottom:18px}
.model-select-row{margin-top:6px;margin-bottom:10px}
.model-select{
  width:100%;background:var(--s2);border:1px solid var(--border2);border-radius:10px;
  color:var(--text);font-size:0.88rem;font-family:var(--font-ui);padding:11px 14px;cursor:pointer;
  outline:none;transition:border-color .18s
}
.model-select:focus{border-color:var(--g1);box-shadow:0 0 0 2px rgba(0,229,255,0.12)}
.model-info-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;min-height:28px}
.model-badge{
  font-size:0.68rem;font-weight:800;padding:3px 9px;border-radius:99px;letter-spacing:.04em;text-transform:uppercase
}
.badge-anthropic{background:rgba(255,107,107,.12);color:#ff9a9a;border:1px solid rgba(255,107,107,.28)}
.badge-openrouter{background:rgba(129,140,248,.12);color:var(--g1);border:1px solid rgba(129,140,248,.35)}
.badge-google{background:rgba(52,211,153,.1);color:var(--g5);border:1px solid rgba(52,211,153,.35)}
.model-id-label{font-size:0.72rem;color:var(--muted);font-family:'DM Mono',monospace;word-break:break-all}
.model-free-tag{
  font-size:0.68rem;color:var(--g5);background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.3);
  border-radius:99px;padding:2px 8px;font-weight:700
}
.usage-bar-wrap{display:flex;align-items:center;gap:10px;margin-top:8px;margin-bottom:6px}
.usage-bar-track{flex:1;height:6px;background:var(--s3);border-radius:99px;overflow:hidden}
.usage-bar-fill{height:100%;border-radius:99px;transition:width .35s ease,background .3s}
.usage-ok{background:var(--g5)}
.usage-warn{background:var(--g4)}
.usage-over{background:var(--g3)}
.usage-label{font-size:0.75rem;color:var(--muted);white-space:nowrap}
.usage-over-text{color:var(--g3)!important;font-weight:700}
.api-key-hint{font-size:0.78rem;color:var(--muted);margin-top:6px;line-height:1.45}
.api-key-hint a{color:var(--g2);text-decoration:underline}
.ai-console-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}

/* ===== GENERATE AREA ===== */
.ai-detail-fieldset{
  border:1px solid var(--border2);
  border-radius:12px;
  padding:12px 14px 14px;
  margin-bottom:18px;
  background:rgba(0,0,0,.12);
}
.ai-detail-fieldset .api-key-label{padding:0 4px}
.ai-detail-hint{font-size:0.78rem;color:var(--muted);margin:0 0 10px;line-height:1.45}
.ai-detail-radios{display:flex;flex-wrap:wrap;gap:14px 20px}
.ai-detail-label{display:flex;align-items:center;gap:8px;font-size:0.88rem;cursor:pointer;color:var(--g5)}
.ai-detail-label input{accent-color:var(--g2)}
.ai-token-usage{font-size:0.75rem;color:var(--muted);margin:10px 0 0;padding:0 2px;line-height:1.4}

.gen-controls{
  display:flex;gap:10px;flex-wrap:wrap;
  margin-bottom:24px;
}

.gbtn{
  padding:13px 26px;
  border-radius:12px;
  font-family:var(--font-ui);
  font-weight:800;
  font-size:0.9rem;
  cursor:pointer;
  border:none;
  transition:all .25s;
  letter-spacing:0.3px;
  display:flex;align-items:center;gap:8px;
}
.gbtn-main{
  background:linear-gradient(135deg,var(--g2),var(--g1));
  color:#000;
  flex:1;
  justify-content:center;
  min-width:180px;
}
.gbtn-main:hover{transform:none;box-shadow:var(--shadow-2)}
.gbtn-main:active{transform:translateY(0)}
.gbtn-outline{
  background:transparent;
  border:1px solid var(--border2);
  color:var(--text);
}
.gbtn-outline:hover{border-color:var(--border2);color:var(--text)}
.gbtn-rand{
  background:rgba(255,184,0,0.1);
  border:1px solid rgba(255,184,0,0.2);
  color:var(--g4);
}

/* ===== AI OUTPUT ===== */
#ai-output{display:none}

.output-card{
  background:linear-gradient(135deg,#0a0a18,#110a1e);
  border:1px solid var(--border2);
  border-radius:18px;
  padding:36px;
  position:relative;
  overflow:hidden;
}
.output-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--g2),var(--g1),var(--g3));
}
.output-card::after{
  content:'';
  position:absolute;bottom:-60px;right:-60px;
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(191,95,255,0.025),transparent 70%);
  pointer-events:none;
}

#stream-content{
  font-family:'DM Mono',monospace;
  font-size:0.83rem;
  line-height:1.8;
  color:var(--text);
  position:relative;z-index:1;
}

/* streaming cursor */
.cursor{
  display:inline-block;
  width:8px;height:14px;
  background:var(--g1);
  border-radius:2px;
  animation:blink .7s ease-in-out infinite;
  vertical-align:middle;
  margin-left:2px;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* markdown styling inside output */
#stream-content h2{
  font-family:var(--font-heading);
  font-size:1.3rem;
  color:var(--text);
  margin:28px 0 10px;
  letter-spacing:-0.5px;
  border-bottom:1px solid var(--border);
  padding-bottom:8px;
}
#stream-content h3{
  font-size:0.88rem;
  font-weight:700;
  color:var(--g1);
  margin:18px 0 8px;
  text-transform:uppercase;
  letter-spacing:1.5px;
}
#stream-content p{margin-bottom:10px;line-height:1.7;font-size:0.85rem}
#stream-content ul{margin:8px 0 12px 0;padding:0}
#stream-content li{
  padding:4px 0 4px 20px;
  position:relative;
  font-size:0.83rem;
  color:var(--muted2);
  line-height:1.5;
}
#stream-content li::before{
  content:'›';
  position:absolute;left:0;
  color:var(--g2);font-size:1rem;
  line-height:1.2;
}
#stream-content strong{color:#fff}
#stream-content code{
  background:rgba(0,229,255,0.08);
  border:1px solid rgba(0,229,255,0.15);
  color:var(--g1);
  padding:1px 7px;
  border-radius:4px;
  font-size:0.82rem;
}
#stream-content .highlight{
  background:rgba(191,95,255,0.1);
  border-left:3px solid var(--g2);
  padding:12px 16px;
  border-radius:0 8px 8px 0;
  margin:12px 0;
}
#stream-content .stack-row{
  display:flex;flex-wrap:wrap;gap:6px;
  margin:10px 0;
}
#stream-content .spill{
  padding:4px 12px;
  border-radius:20px;
  font-size:10px;
  font-weight:700;
}

/* ===== LOADING ===== */
.loading-bar{
  display:none;
  background:var(--s1);
  border:1px solid var(--border);
  border-radius:12px;
  padding:20px 24px;
  margin-bottom:20px;
  align-items:center;gap:14px;
}
.loading-bar.show{display:flex}
.loader{
  width:20px;height:20px;
  border:2px solid rgba(0,229,255,0.15);
  border-top-color:var(--g1);
  border-radius:50%;
  animation:spin .6s linear infinite;
  flex-shrink:0;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{
  font-family:'DM Mono',monospace;
  font-size:0.8rem;
  color:var(--g1);
}
.loading-sub{
  font-size:0.72rem;
  color:var(--muted);
  margin-top:2px;
}

/* ===== SELECTED SUMMARY ===== */
.selected-summary{
  display:flex;flex-wrap:wrap;gap:6px;
  min-height:32px;
  padding:12px 16px;
  background:var(--s2);
  border:1px solid var(--border);
  border-radius:10px;
  margin-bottom:16px;
  align-items:center;
}
.sum-empty{font-family:'DM Mono',monospace;font-size:0.75rem;color:var(--muted)}
.sum-pill{
  display:flex;align-items:center;gap:5px;
  padding:3px 10px;
  background:var(--s3);
  border:1px solid var(--border2);
  border-radius:20px;
  font-size:11px;
  font-family:'DM Mono',monospace;
  color:var(--text);
}
.sum-pill button{
  background:none;border:none;
  color:var(--muted);cursor:pointer;
  font-size:12px;line-height:1;padding:0;
  transition:color .15s;
}
.sum-pill button:hover{color:var(--g3)}

/* ===== FAMOUS PROJECTS DB ===== */
.founders-db{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:14px;
}

.founder-card{
  background:var(--s2);
  border:1px solid var(--border);
  border-radius:14px;
  padding:20px;
  position:relative;overflow:hidden;
}
.founder-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:2px;
}
.founder-top{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.founder-logo{
  width:44px;height:44px;
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  border:1px solid var(--border);
}
.founder-info .fname{
  font-weight:800;font-size:1rem;margin-bottom:2px;
}
.founder-info .fcategory{
  font-size:0.73rem;
  font-family:'DM Mono',monospace;
  color:var(--muted);
  letter-spacing:1px;
  text-transform:uppercase;
}
.founder-info .fval{
  font-family:'DM Mono',monospace;
  font-size:0.72rem;
  color:var(--g4);
  margin-top:4px;
}

.founder-stack{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}
.founder-stack.collapse .fstack-tag.hidden{display:none}

.fstack-tag{
  font-size:9px;
  font-family:'DM Mono',monospace;
  padding:2px 8px;border-radius:4px;
  background:var(--s3);
  border:1px solid var(--border);
  color:var(--muted2);
}

.founder-people{border-top:1px solid var(--border);padding-top:12px}
.fp-label{font-size:9px;font-family:'DM Mono',monospace;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}

.fp-person{
  display:flex;align-items:center;gap:8px;
  padding:5px 0;
  border-bottom:1px solid rgba(255,255,255,0.03);
}
.fp-person:last-child{border-bottom:none}
.fp-avatar{
  width:28px;height:28px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:0.75rem;font-weight:700;
  flex-shrink:0;
  box-sizing:border-box;
  border:1px solid var(--border2);
  background:var(--s3);
  color:var(--text-secondary);
}
/* Iniciais com acento: fundo escuro + cor viva = contraste AA */
.fp-avatar-accent{
  background:rgba(8,8,14,0.92);
  color:var(--av, var(--g1));
  border:1px solid rgba(255,255,255,0.14);
}
@supports (border-color:color-mix(in srgb, white, black)){
  .fp-avatar-accent{
    border-color:color-mix(in srgb, var(--av, var(--g1)) 52%, rgba(255,255,255,0.1));
  }
}
.fp-avatar-engineer{
  background:rgba(255,255,255,0.11);
  color:#e4e4e7;
  border-color:rgba(255,255,255,0.24);
}
.fp-details .fp-name{font-size:0.8rem;font-weight:700}
.fp-details .fp-role{font-size:0.7rem;font-family:'DM Mono',monospace;color:var(--muted)}

/* ===== INNOVATIONS TAB ===== */
.innov-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:14px;
}

.innov-card{
  background:var(--s2);
  border:1px solid var(--border);
  border-radius:14px;
  padding:20px;
  position:relative;overflow:hidden;
  transition:all .2s;
}
.innov-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.innov-card::before{
  content:'';
  position:absolute;top:0;left:0;width:3px;height:100%;
}
.innov-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.innov-title{font-weight:800;font-size:0.95rem}
.innov-year{
  font-family:'DM Mono',monospace;
  font-size:9px;
  padding:2px 8px;border-radius:20px;
  background:rgba(255,255,255,0.05);
  color:var(--muted);
  border:1px solid var(--border);
}
.innov-desc{font-size:0.8rem;color:var(--muted2);line-height:1.5;margin-bottom:12px}
.innov-used{
  font-family:'DM Mono',monospace;
  font-size:9px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:1px;
  margin-bottom:6px;
}
.innov-companies{display:flex;flex-wrap:wrap;gap:4px}
.innov-companies.collapse .innov-co.hidden{display:none}
.innov-co{
  font-size:9px;
  font-family:'DM Mono',monospace;
  padding:2px 7px;border-radius:4px;
  background:var(--s3);
  color:var(--muted2);
  border:1px solid var(--border);
}

/* ===== OUTPUT ACTIONS ===== */
.output-actions{
  display:flex;gap:10px;flex-wrap:wrap;
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid var(--border);
}

/* ===== SELECTION FOOTER (resumo builder) ===== */
.selection-footer{
  position:fixed;
  bottom:0;
  left:var(--sidebar-w);
  right:0;
  top:auto;
  z-index:400;
  display:flex;
  flex-direction:column;
  max-width:none;
  border-top:1px solid var(--border2);
  border-bottom:none;
  border-left:none;
  border-right:none;
  background:rgba(8,8,14,0.92);
  backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  box-shadow:0 -2px 12px rgba(0,0,0,0.08);
  padding-bottom:max(0px,env(safe-area-inset-bottom));
  transition:box-shadow .2s ease,border-color .2s ease;
}
.selection-footer.is-dragging{
  opacity:0.96;
  box-shadow:var(--shadow-3);
  z-index:450;
}
.selection-footer-toolbar{
  flex-shrink:0;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:3px;
  padding:4px 8px 6px;
  border-bottom:1px solid rgba(255,255,255,0.06);
  background:rgba(0,0,0,0.2);
}
.selection-footer-toolbar .footer-toolbar-sep{
  width:1px;
  height:16px;
  background:var(--border);
  margin:0 3px;
  flex-shrink:0;
}
.footer-toolbar-drag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:8px;
  border:1px dashed var(--border2);
  color:var(--text-tertiary);
  cursor:grab;
  flex-shrink:0;
  touch-action:none;
  user-select:none;
}
.footer-toolbar-drag:active{cursor:grabbing}
.footer-toolbar-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  padding:0;
  border-radius:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,0.04);
  color:var(--text-tertiary);
  cursor:pointer;
  transition:color .15s,border-color .15s,background .15s;
  flex-shrink:0;
}
.footer-toolbar-btn:hover{
  color:var(--text-tertiary);
  border-color:var(--border);
  background:rgba(255,255,255,0.04);
}
.footer-toolbar-btn.is-active,
.footer-toolbar-btn[aria-pressed="true"]{
  color:var(--g1);
  border-color:rgba(0,229,255,0.35);
  background:rgba(0,229,255,0.08);
}
.footer-toolbar-btn.footer-dock-active{
  color:var(--g2);
  border-color:rgba(191,95,255,0.35);
  background:rgba(191,95,255,0.08);
}
.footer-toolbar-btn .material-symbols-outlined{font-size:16px;font-variation-settings:'FILL' 0,'wght' 350,'GRAD' 0,'opsz' 20}
.footer-toolbar-drag .material-symbols-outlined{font-size:16px;font-variation-settings:'FILL' 0,'wght' 350,'GRAD' 0,'opsz' 20}
.selection-footer-body{
  flex:1;
  min-height:0;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.selection-footer.is-collapsed .selection-footer-body{
  display:none;
}
.selection-footer-inner{
  max-width:1200px;margin:0 auto;width:100%;
  padding:10px 20px 12px;
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
}
/* Ancoragem: fundo */
.selection-footer[data-dock="bottom"]{
  bottom:0;top:auto;left:var(--sidebar-w);right:0;
  flex-direction:column;
  border-top:1px solid var(--border2);
  border-bottom:none;
  box-shadow:0 -2px 12px rgba(0,0,0,0.08);
}
.selection-footer[data-dock="bottom"] .selection-footer-toolbar{
  order:0;
}
.selection-footer[data-dock="bottom"] .selection-footer-body{order:1}
/* Ancoragem: topo */
.selection-footer[data-dock="top"]{
  top:0;bottom:auto;left:var(--sidebar-w);right:0;
  flex-direction:column-reverse;
  border-bottom:1px solid var(--border2);
  border-top:none;
  box-shadow:0 2px 12px rgba(0,0,0,0.08);
}
/* Lateral esquerda (à direita da sidebar) */
.selection-footer[data-dock="left"]{
  top:0;bottom:0;left:var(--sidebar-w);right:auto;
  width:min(92vw,300px);
  flex-direction:column;
  border-right:1px solid var(--border2);
  border-top:none;
  box-shadow:2px 0 10px rgba(0,0,0,0.08);
}
.selection-footer[data-dock="left"] .selection-footer-inner{
  max-width:none;
  padding:10px 12px;
  overflow-y:auto;
}
/* Lateral direita */
.selection-footer[data-dock="right"]{
  top:0;bottom:0;right:0;left:auto;
  width:min(92vw,300px);
  flex-direction:column;
  border-left:1px solid var(--border2);
  border-top:none;
  box-shadow:-2px 0 10px rgba(0,0,0,0.08);
}
.selection-footer[data-dock="right"] .selection-footer-inner{
  max-width:none;
  padding:10px 12px;
  overflow-y:auto;
}
/* Flutuante (posição via JS inline) */
.selection-footer[data-dock="float"]{
  left:auto;
  right:auto;
  top:auto;
  bottom:auto;
  width:min(96vw,400px);
  max-height:min(78vh,620px);
  flex-direction:column;
  border:1px solid var(--border2);
  border-radius:16px;
  box-shadow:var(--shadow-3);
  overflow:hidden;
}
.selection-footer[data-dock="float"] .selection-footer-inner{
  max-width:none;
  overflow-y:auto;
  flex:1;
  min-height:0;
}
.selection-footer[data-dock="left"] .selection-footer-stack,
.selection-footer[data-dock="right"] .selection-footer-stack,
.selection-footer[data-dock="float"] .selection-footer-stack{
  flex-direction:column;
  align-items:stretch;
}
.selection-footer[data-dock="left"] .footer-stack-scroll,
.selection-footer[data-dock="right"] .footer-stack-scroll,
.selection-footer[data-dock="float"] .footer-stack-scroll{
  flex-wrap:wrap;
  overflow-x:hidden;
  overflow-y:auto;
  max-height:min(28vh,200px);
}
.selection-footer[data-dock="left"] .selection-footer-actions,
.selection-footer[data-dock="right"] .selection-footer-actions,
.selection-footer[data-dock="float"] .selection-footer-actions{
  flex-direction:column;
  align-items:stretch;
}
.selection-footer[data-dock="left"] .gbtn-footer,
.selection-footer[data-dock="right"] .gbtn-footer,
.selection-footer[data-dock="float"] .gbtn-footer{
  width:100%;
  justify-content:center;
}
.selection-footer-row{
  display:flex;align-items:center;gap:10px;
  flex-wrap:wrap;
}
.selection-footer-meta{
  gap:8px;
  margin-bottom:8px;
}
.footer-chip{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'DM Mono',monospace;
  font-size:10px;
  padding:5px 11px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--s2);
  color:var(--muted2);
  max-width:100%;
}
.footer-chip b,.footer-chip strong{font-weight:600;color:var(--text)}
.footer-chip-muted{color:var(--muted)}
.footer-chip-ok{
  border-color:rgba(0,255,140,0.35);
  background:rgba(0,255,140,0.08);
  color:var(--g5);
}
.footer-chip-warn{
  border-color:rgba(250,204,21,0.42);
  background:rgba(45,35,12,0.78);
  color:#fef08a;
}
.footer-chip-accent{
  border-color:rgba(0,229,255,0.3);
  background:rgba(0,229,255,0.08);
  color:var(--g1);
}
.selection-footer-stack{
  align-items:flex-start;
  gap:8px;
  margin-bottom:8px;
}
.footer-stack-label{
  flex-shrink:0;
  font-family:'DM Mono',monospace;
  font-size:9px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--muted);
  padding-top:6px;
}
.footer-stack-scroll{
  flex:1;
  min-width:0;
  display:flex;flex-wrap:nowrap;gap:5px;
  overflow-x:auto;
  overflow-y:hidden;
  padding:2px 2px 6px;
  scrollbar-width:thin;
  -webkit-overflow-scrolling:touch;
}
.footer-tech-pill{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px 3px 9px;
  border-radius:20px;
  font-size:10px;
  font-family:'DM Mono',monospace;
  background:var(--s3);
  border:1px solid var(--border2);
  color:var(--text);
}
.footer-tech-pill button{
  background:none;border:none;
  color:var(--muted);cursor:pointer;
  font-size:12px;line-height:1;padding:0 0 0 2px;
  border-radius:4px;
}
.footer-tech-pill button:hover{color:var(--g3)}
.selection-footer-actions{
  gap:8px;
  padding-top:2px;
  border-top:1px solid rgba(255,255,255,0.04);
  margin:0 -4px 0;
  padding-left:4px;padding-right:4px;
}
.gbtn-footer{
  padding:8px 14px !important;
  font-size:0.78rem !important;
  min-height:0;
  border-radius:10px;
  letter-spacing:0;
}
.selection-footer .gbtn-main{
  flex:0 1 auto;
  min-width:0;
  justify-content:center;
}
.selection-footer-actions .material-symbols-outlined{font-size:18px}
@media(max-width:600px){
  .selection-footer-inner{padding:8px 12px 10px}
  .selection-footer-actions{justify-content:flex-start}
  .gbtn-footer{padding:7px 10px !important;font-size:0.72rem !important}
}

/* ===== APP MODAL (substitui alert) ===== */
.app-modal{
  position:fixed;inset:0;z-index:5000;
  display:flex;align-items:center;justify-content:center;padding:24px 16px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .24s ease,visibility .24s ease;
}
.app-modal.is-open{
  opacity:1;visibility:visible;pointer-events:auto;
}
.app-modal-backdrop{
  position:absolute;inset:0;
  background:rgba(5,5,8,0.78);
  backdrop-filter:blur(14px) saturate(1.15);
  -webkit-backdrop-filter:blur(14px) saturate(1.15);
}
.app-modal-panel{
  position:relative;width:100%;max-width:440px;
  background:linear-gradient(160deg,rgba(22,22,36,0.98) 0%,rgba(12,12,18,0.99) 100%);
  border:1px solid var(--border2);
  border-radius:20px;
  padding:32px 28px 26px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.04) inset,
    var(--shadow-3);
  transform:translateY(14px) scale(0.97);
  opacity:0;
  transition:transform .32s cubic-bezier(.22,1,.36,1),opacity .26s ease;
}
.app-modal.is-open .app-modal-panel{
  transform:translateY(0) scale(1);
  opacity:1;
}
.app-modal-glow{
  position:absolute;top:0;left:50%;width:min(320px,78%);height:2px;
  transform:translate(-50%,-1px);
  border-radius:2px;
  background:linear-gradient(90deg,transparent,var(--g1),var(--g2),transparent);
  opacity:.9;
}
.app-modal[data-variant="success"] .app-modal-glow{
  background:linear-gradient(90deg,transparent,var(--g5),var(--g1),transparent);
}
.app-modal[data-variant="warning"] .app-modal-glow{
  background:linear-gradient(90deg,transparent,var(--g4),var(--g3),transparent);
}
.app-modal[data-variant="error"] .app-modal-glow{
  background:linear-gradient(90deg,transparent,var(--g3),var(--g4),transparent);
}
.app-modal-close{
  position:absolute;top:14px;right:14px;
  width:38px;height:38px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);
  background:rgba(255,255,255,0.04);
  color:var(--muted2);
  cursor:pointer;
  transition:color .15s,border-color .15s,background .15s;
}
.app-modal-close:hover{
  color:var(--muted2);
  border-color:var(--border);
  background:rgba(255,255,255,0.04);
}
.app-modal-close .material-symbols-outlined{font-size:22px}
.app-modal-icon-wrap{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
  background:rgba(0,229,255,0.1);
  border:1px solid rgba(0,229,255,0.22);
  color:var(--g1);
}
.app-modal-icon-wrap .material-symbols-outlined{font-size:28px}
.app-modal[data-variant="success"] .app-modal-icon-wrap{
  background:rgba(0,255,140,0.1);
  border-color:rgba(0,255,140,0.25);
  color:var(--g5);
}
.app-modal[data-variant="warning"] .app-modal-icon-wrap{
  background:rgba(255,184,0,0.1);
  border-color:rgba(255,184,0,0.28);
  color:var(--g4);
}
.app-modal[data-variant="error"] .app-modal-icon-wrap{
  background:rgba(255,61,110,0.1);
  border-color:rgba(255,61,110,0.28);
  color:var(--g3);
}
.app-modal-kicker{
  font-family:'DM Mono',monospace;
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:8px;
}
.app-modal-kicker:empty{display:none}
.app-modal-title{
  font-family:var(--font-heading);
  font-size:1.35rem;
  font-weight:600;
  letter-spacing:-0.5px;
  line-height:1.2;
  margin-bottom:12px;
  color:var(--text);
}
.app-modal-message{
  font-size:0.9rem;
  line-height:1.65;
  color:var(--muted2);
  margin-bottom:22px;
}
.app-modal-actions{
  display:flex;justify-content:flex-end;gap:10px;
  padding-top:4px;
}
@media (prefers-reduced-motion:reduce){
  .app-modal,.app-modal-panel{transition:none}
  .app-modal.is-open .app-modal-panel{transform:none}
}

/* ===== PRÉ-VISUALIZAÇÃO PROJETO (popover ancorado, estilo Stories) ===== */
.proj-preview-modal{
  position:fixed;inset:0;z-index:4800;
  display:block;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .22s ease,visibility .22s ease;
}
.proj-preview-modal.is-open{
  opacity:1;visibility:visible;pointer-events:auto;
}
.proj-preview-backdrop{
  position:absolute;inset:0;z-index:0;
  background:rgba(5,5,10,0.58);
}
.proj-preview-panel{
  position:fixed;
  z-index:1;
  left:0;
  top:0;
  width:min(250px,calc(100vw - 20px));
  max-width:250px;
  margin:0;
  overflow:visible;
  overscroll-behavior:contain;
  box-sizing:border-box;
  background:linear-gradient(165deg,rgba(24,22,40,0.98) 0%,rgba(10,10,18,0.99) 100%);
  border:1px solid var(--border2);
  border-radius:22px;
  padding:20px 18px 16px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.05) inset,
    0 20px 56px rgba(0,0,0,0.45),
    0 0 40px rgba(191,95,255,0.08);
  transform:translateY(10px) scale(0.98);
  opacity:0;
  transition:transform .28s cubic-bezier(.22,1,.36,1),opacity .24s ease,top .2s ease,left .2s ease,width .2s ease;
}
.proj-preview-panel[data-placement="below"]::before{
  content:'';
  position:absolute;
  top:-7px;
  left:var(--pp-caret-left,50%);
  transform:translateX(-50%);
  width:0;height:0;
  border-left:7px solid transparent;
  border-right:7px solid transparent;
  border-bottom:7px solid rgba(36,34,52,0.98);
  filter:drop-shadow(0 -1px 0 rgba(255,255,255,0.06));
  pointer-events:none;
}
.proj-preview-panel[data-placement="above"]::after{
  content:'';
  position:absolute;
  bottom:-7px;
  left:var(--pp-caret-left,50%);
  transform:translateX(-50%);
  width:0;height:0;
  border-left:7px solid transparent;
  border-right:7px solid transparent;
  border-top:7px solid rgba(14,14,22,0.99);
  filter:drop-shadow(0 1px 0 rgba(255,255,255,0.05));
  pointer-events:none;
}
.proj-preview-panel[data-placement="side"]::before,
.proj-preview-panel[data-placement="side"]::after{
  display:none;
}
.proj-preview-modal.is-open .proj-preview-panel{
  transform:translateY(0) scale(1);
  opacity:1;
}
.proj-preview-close{
  position:absolute;top:12px;right:12px;
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);
  background:rgba(255,255,255,0.06);
  color:var(--muted2);
  cursor:pointer;
  z-index:2;
  transition:color .15s,border-color .15s,background .15s;
}
.proj-preview-close:hover{
  color:var(--text);
  border-color:var(--border2);
  background:rgba(191,95,255,0.12);
}
.proj-preview-close .material-symbols-outlined{font-size:22px}
.proj-preview-kicker{
  font-family:'DM Mono',monospace;
  font-size:9px;
  letter-spacing:2.2px;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:6px;
  padding-right:48px;
}
.proj-preview-title{
  font-family:var(--font-heading);
  font-size:1.05rem;
  font-weight:600;
  letter-spacing:-0.3px;
  line-height:1.25;
  margin-bottom:14px;
  color:var(--text);
  padding-right:44px;
}
.proj-preview-viewport{
  position:relative;
  width:100%;
  aspect-ratio:4/5;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(0,0,0,0.35);
  touch-action:pan-y;
}
.proj-preview-img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  user-select:none;
  -webkit-user-drag:none;
}
.proj-preview-segments{
  display:flex;
  gap:5px;
  margin-top:12px;
  align-items:center;
}
.proj-preview-seg{
  flex:1;
  height:3px;
  border-radius:2px;
  background:rgba(255,255,255,0.18);
  overflow:hidden;
}
.proj-preview-seg-fill{
  display:block;
  height:100%;
  width:100%;
  transform-origin:left center;
  transform:scaleX(0);
  background:linear-gradient(90deg,var(--g1),var(--g2));
  border-radius:2px;
  will-change:transform;
}
.proj-preview-seg.is-done .proj-preview-seg-fill{
  transform:scaleX(1);
  transition:none;
}
.proj-preview-seg.is-active .proj-preview-seg-fill{
  transform:scaleX(0);
}
.proj-preview-modal.reduced-motion .proj-preview-seg.is-active .proj-preview-seg-fill{
  transform:scaleX(1);
  opacity:0.85;
}
@media(max-width:480px){
  .proj-preview-panel{width:min(250px,calc(100vw - 16px));max-width:250px;border-radius:18px;padding:16px 14px 14px}
  .proj-preview-viewport{border-radius:14px}
}
@media (prefers-reduced-motion:reduce){
  .proj-preview-modal,.proj-preview-panel{transition:none}
  .proj-preview-modal.is-open .proj-preview-panel{transform:none}
}

/* ===== PRINT / PDF (só saída gerada) ===== */
@media print {
  body{background:#fff !important;color:#111 !important;padding-bottom:0 !important}
  body::before,body::after,.theme-toggle,.app-modal,.proj-preview-modal,.selection-footer{display:none !important}
  .app-page-header,.app-sidebar{display:none !important}
  .tab-panel{display:none !important}
  #panel-builder{display:block !important}
  #panel-builder > *:not(#ai-output){display:none !important}
  #ai-loading{display:none !important}
  #ai-output{display:block !important;position:static !important}
  #ai-output .output-actions{display:none !important}
  .wrap{max-width:100% !important;padding:12px !important}
  .output-card{background:#fff !important;border:1px solid #ccc !important;box-shadow:none !important}
  #stream-content{color:#111 !important;font-size:11pt;line-height:1.45}
  #stream-content h2{color:#111 !important;border-color:#ccc !important}
  #stream-content h3{color:#333 !important}
  #stream-content code{background:#f4f4f4 !important;border:1px solid #ddd !important;color:#222 !important}
  #stream-content li{color:#333 !important}
}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .app-shell{flex-direction:column}
  .app-sidebar{
    width:100% !important;
    min-width:0 !important;
    max-width:none !important;
    height:auto;
    min-height:var(--app-mobile-rail-h);
    flex-direction:row;
    flex-wrap:nowrap;
    position:fixed;
    left:0;
    right:0;
    top:0;
    padding-top:max(8px, env(safe-area-inset-top, 0px));
    padding-left:max(10px, env(safe-area-inset-left, 0px));
    padding-right:max(10px, env(safe-area-inset-right, 0px));
    padding-bottom:10px;
    border-right:none;
    border-bottom:1px solid var(--border);
    gap:10px;
    justify-content:center;
    align-items:center;
    z-index:250;
    box-shadow:0 8px 24px rgba(0,0,0,0.35);
  }
  .app-main{
    padding-top:calc(var(--app-mobile-rail-h) + max(4px, env(safe-area-inset-top, 0px)));
  }
  .sidebar-slide-toggle{display:none !important}
  .app-sidebar .sidebar-item-label{display:none !important}
  .sidebar-nav{
    flex-direction:row;
    flex:1 1 auto;
    justify-content:center;
    align-items:center;
    padding:0;
    overflow-x:auto;
    overflow-y:hidden;
    gap:10px;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-x:contain;
    touch-action:pan-x;
    scrollbar-width:thin;
    min-width:0;
  }
  .sidebar-item.tab-btn,
  button.sidebar-item{
    width:38px;
    height:38px;
    min-width:38px;
    min-height:38px;
    border-radius:13px;
  }
  .sidebar-item .material-symbols-outlined{
    font-size:18px;
  }
  .sidebar-spacer{display:none}
  .selection-footer[data-dock="bottom"],
  .selection-footer[data-dock="top"]{left:0;right:0}
  .selection-footer[data-dock="left"]{left:0;width:min(96vw,280px)}
}
@media(max-width:600px){
  .proj-grid{grid-template-columns:repeat(3,1fr)}
  .sites-grid{grid-template-columns:1fr}
  .tech-mega{grid-template-columns:1fr}
}

/* Mobile estreito (≈400–500px): menos padding, header e IA centrados, complexidade com scroll horizontal */
@media(max-width:560px){
  .wrap{
    max-width:100%;
    width:100%;
    margin:0 auto;
    padding:14px 10px max(140px, calc(var(--selection-footer-h) + 24px));
    box-sizing:border-box;
  }
  .app-page-header{
    flex-direction:row;
    flex-wrap:nowrap;
    align-items:center;
    justify-content:space-between;
    gap:8px;
    text-align:left;
    padding:10px 10px 10px;
    padding-left:max(10px, env(safe-area-inset-left, 0px));
    padding-right:max(10px, env(safe-area-inset-right, 0px));
  }
  .header-eyebrow{
    flex:1 1 auto;
    min-width:0;
    justify-content:flex-start;
    max-width:100%;
    text-align:left;
    padding:5px 10px;
    font-size:10px;
    letter-spacing:0.12em;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .header-theme-bar{
    margin-left:0;
    flex:0 0 auto;
    width:auto;
    justify-content:flex-end;
    flex-wrap:nowrap;
    gap:5px;
    min-width:0;
  }
  .header-theme-mark{
    font-size:17px;
    flex-shrink:0;
  }
  .header-theme-name{
    text-align:right;
    font-size:9px;
    min-width:2.5em;
    flex-shrink:0;
  }
  /* Switch de tema mais compacto no telemóvel */
  .header-theme-switch-wrap .switch{
    font-size:0.68rem;
    width:2.55em;
    height:1.42em;
  }
  .header-theme-switch-wrap .slider::before{
    width:1.02em;
    height:1.02em;
    left:0.16em;
  }
  .header-theme-switch-wrap input:checked + .slider::before{
    transform:translateY(-50%) translateX(calc(2.55em - 1.02em - 0.32em));
  }
  .card{
    padding:16px 11px;
    margin-bottom:16px;
    border-radius:14px;
    width:100%;
    max-width:min(100%, 520px);
    margin-left:auto;
    margin-right:auto;
    box-sizing:border-box;
  }
  #step-generate.card{
    padding-left:11px;
    padding-right:11px;
    margin-bottom:clamp(100px, 28vw, 130px);
  }
  .sec-head{
    flex-wrap:wrap;
    justify-content:center;
    text-align:center;
    gap:8px;
    margin-bottom:14px;
  }
  .sec-line{
    flex:1 1 72px;
    min-width:48px;
  }
  .complexity-row{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }
  .complexity-labels{
    display:flex;
    flex-direction:row;
    flex-wrap:nowrap;
    overflow:visible;
    overflow-x:auto;
    overflow-y:visible;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-x:contain;
    touch-action:pan-x;
    scroll-snap-type:x proximity;
    max-width:100%;
    width:100%;
    border-radius:10px;
  }
  .complexity-labels::-webkit-scrollbar{
    height:4px;
  }
  .complexity-labels::-webkit-scrollbar-thumb{
    background:var(--border2);
    border-radius:99px;
  }
  .clabel{
    scroll-snap-align:start;
    padding:10px 14px;
    font-size:0.74rem;
  }
  .proj-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
    justify-items:stretch;
  }
  .proj-card{
    padding:12px 8px;
  }
  .api-key-intro{
    text-align:center;
    font-size:0.8rem;
    padding:0 2px;
  }
  .model-selector-wrap{
    text-align:center;
  }
  .model-info-row{
    justify-content:center;
  }
  .ai-console-actions,
  .gen-controls{
    justify-content:center;
    width:100%;
  }
  .ai-console-actions .gbtn,
  .gen-controls .gbtn{
    flex:1 1 auto;
    min-width:0;
    justify-content:center;
  }
  .api-key-row{
    flex-direction:column;
    align-items:stretch;
  }
  .api-key-input{
    min-width:0;
    width:100%;
  }
  .api-key-box{
    padding:12px 10px;
  }
  .selected-summary{
    text-align:center;
  }
}

/* color themes for site cards */
.theme-cyan::before{background:linear-gradient(90deg,var(--g1),transparent)}
.theme-purple::before{background:linear-gradient(90deg,var(--g2),transparent)}
.theme-pink::before{background:linear-gradient(90deg,var(--g3),transparent)}
.theme-gold::before{background:linear-gradient(90deg,var(--g4),transparent)}
.theme-green::before{background:linear-gradient(90deg,var(--g5),transparent)}

/* scroll to top fade-in */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.card{animation:fadeUp .4s ease both}
