/**
 * © Alessandro Castagna — 321.al / EVOLAB
 * Tutti i diritti riservati. Uso non autorizzato vietato.
 * info@321.it · https://321.al
 */

:root{
  --bg:#07080c; --bg2:#0b0e16; --panel:#11151f; --panel2:#0e121b;
  --text:#e9edf6; --muted:#8b93a7; --line:rgba(255,255,255,.08);
  --accent:#00d4ff; --accent2:#7c5cff; --accent3:#ff4d6d;
  --radius:18px; --maxw:1140px;
  --shadow:0 24px 60px -20px rgba(0,0,0,.7);
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --display:"Space Grotesk",var(--font);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font); color:var(--text);
  background:radial-gradient(1200px 700px at 70% -10%, #141a2b 0%, transparent 60%),
             radial-gradient(900px 600px at 0% 20%, #16101f 0%, transparent 55%), var(--bg);
  line-height:1.55; -webkit-font-smoothing:antialiased; min-height:100vh;
  display:flex; flex-direction:column;
}
.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:24px; width:100%}
a{color:inherit; text-decoration:none}
h1,h2,h3{font-family:var(--display); font-weight:600; letter-spacing:-.02em; line-height:1.1}
main{flex:1}

/* ---------- Topbar ---------- */
.topbar{position:sticky; top:0; z-index:30; backdrop-filter:blur(12px);
  background:linear-gradient(to bottom, rgba(7,8,12,.85), rgba(7,8,12,.4));
  border-bottom:1px solid var(--line)}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; height:64px}
.brand{font-family:var(--display); font-weight:700; font-size:18px; letter-spacing:.02em; display:flex; align-items:center; gap:8px}
.brand-mark{color:var(--accent); filter:drop-shadow(0 0 8px var(--accent))}
.nav{display:flex; align-items:center; gap:26px; font-size:14px; color:var(--muted)}
.nav a{transition:color .2s} .nav a:hover{color:var(--text)}
.nav-cta{padding:8px 16px; border:1px solid var(--line); border-radius:999px; color:var(--text)!important;
  background:rgba(255,255,255,.03); transition:.2s}
.nav-cta:hover{border-color:var(--accent); box-shadow:0 0 0 1px var(--accent), 0 0 24px -6px var(--accent)}

/* ---------- Hero ---------- */
.hero{position:relative; overflow:hidden; padding:clamp(60px,12vh,120px) 0 90px; text-align:center}
.hero-glow{position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(600px 380px at 50% 8%, rgba(124,92,255,.28), transparent 60%),
            radial-gradient(540px 360px at 50% 90%, rgba(0,212,255,.18), transparent 60%)}
.hero-inner{position:relative; z-index:2; display:flex; flex-direction:column; align-items:center}
.eyebrow{font-size:12px; letter-spacing:.28em; text-transform:uppercase; color:var(--muted); margin-bottom:18px}
.hero-title{font-size:clamp(38px,7vw,76px); margin-bottom:18px;
  background:linear-gradient(180deg,#fff, #b9c0d6); -webkit-background-clip:text; background-clip:text; color:transparent}
.hero-sub{max-width:560px; color:var(--muted); font-size:clamp(15px,2vw,18px); margin-bottom:54px}

/* ---------- Projects orb (pulsante avveniristico) ---------- */
.projects-orb{position:relative; width:min(240px,62vw); aspect-ratio:1; border-radius:50%;
  display:grid; place-items:center; isolation:isolate; transition:transform .25s cubic-bezier(.2,.8,.2,1); will-change:transform}
.projects-orb:hover{transform:scale(1.04)}
.orb-ring{position:absolute; inset:-2px; border-radius:50%; z-index:-1;
  background:conic-gradient(from 0deg, var(--accent), var(--accent2), var(--accent3), var(--accent));
  filter:blur(2px); animation:spin 6s linear infinite;
  -webkit-mask:radial-gradient(closest-side, transparent 70%, #000 72%);
          mask:radial-gradient(closest-side, transparent 70%, #000 72%)}
.projects-orb::after{content:""; position:absolute; inset:8px; border-radius:50%; z-index:-1;
  background:radial-gradient(circle at 50% 35%, rgba(124,92,255,.55), rgba(0,212,255,.12) 60%, transparent 75%);
  filter:blur(14px); animation:pulse 3.4s ease-in-out infinite}
.orb-core{width:78%; aspect-ratio:1; border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px;
  background:radial-gradient(circle at 50% 30%, #161b29, #0a0d15 70%);
  border:1px solid rgba(255,255,255,.12); box-shadow:inset 0 1px 0 rgba(255,255,255,.12), var(--shadow)}
.orb-label{font-family:var(--display); font-weight:600; font-size:clamp(20px,3.4vw,28px); letter-spacing:.01em}
.orb-sub{font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted)}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:.7; transform:scale(.96)}50%{opacity:1; transform:scale(1.04)}}

/* ---------- Sections ---------- */
.section{padding:84px 0; border-top:1px solid var(--line)}
.section.alt{background:linear-gradient(180deg, rgba(255,255,255,.015), transparent)}
.section-head{margin-bottom:40px}
.section-head h2{font-size:clamp(26px,4vw,40px)}
.section-head p{color:var(--muted); margin-top:8px}

/* ---------- Cards grid ---------- */
.grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px}
.card{position:relative; padding:24px; border-radius:var(--radius); background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line); overflow:hidden; transition:transform .25s, border-color .25s}
.card::before{content:""; position:absolute; left:0; top:0; height:3px; width:100%;
  background:linear-gradient(90deg, var(--accent), transparent 70%); opacity:.9}
.card:hover{transform:translateY(-4px); border-color:color-mix(in srgb, var(--accent) 50%, var(--line))}
.card-top{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:10px}
.card-top h3{font-size:20px}
.badge{font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
  border:1px solid var(--line); padding:4px 10px; border-radius:999px; white-space:nowrap; background:rgba(255,255,255,.02)}
.card-tagline{font-weight:500; margin-bottom:8px}
.card-desc{color:var(--muted); font-size:14px; margin-bottom:18px}
.card-foot{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap}
.tags{display:flex; gap:6px; flex-wrap:wrap}
.tag{font-size:11px; color:var(--muted); background:rgba(255,255,255,.04); border:1px solid var(--line); padding:3px 9px; border-radius:8px}
.card-link{font-size:13px; color:var(--accent); white-space:nowrap}
.card-link:hover{text-decoration:underline}
.card.client .code{font-family:var(--display); font-weight:700; font-size:18px; letter-spacing:.06em; color:var(--accent)}
.client-name{font-size:13px; color:var(--text); margin-bottom:10px; opacity:.9}
.links{display:flex; gap:14px; flex-wrap:wrap; font-size:13px}
.links a{color:var(--accent)} .links a:hover{text-decoration:underline}

/* ---------- Two col / panel / CTA ---------- */
.two-col{display:grid; grid-template-columns:1.2fr .8fr; gap:32px; align-items:start}
.two-col h2{font-size:clamp(24px,3.4vw,34px); margin-bottom:14px}
.lead{color:var(--muted); margin-bottom:18px}
.ticks{list-style:none; display:grid; gap:10px}
.ticks li{position:relative; padding-left:26px; color:var(--text)}
.ticks li::before{content:"✓"; position:absolute; left:0; color:var(--accent); font-weight:700}
.panel{padding:26px; border-radius:var(--radius); background:linear-gradient(180deg,var(--panel),var(--panel2)); border:1px solid var(--line)}
.panel h3{margin-bottom:10px} .panel p{color:var(--muted); font-size:14px}
.panel a{color:var(--accent)}
.cta-band{display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  padding:34px; border-radius:var(--radius);
  background:linear-gradient(120deg, rgba(124,92,255,.16), rgba(0,212,255,.10)); border:1px solid var(--line)}
.cta-band h2{font-size:clamp(22px,3vw,30px); margin-bottom:6px} .cta-band p{color:var(--muted)}

.btn-primary{display:inline-block; font-weight:600; padding:14px 26px; border-radius:999px; color:#06080d!important;
  background:linear-gradient(120deg,var(--accent),var(--accent2)); box-shadow:0 10px 30px -10px var(--accent2); transition:.2s; border:none; cursor:pointer; font-size:15px}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 16px 40px -10px var(--accent2)}
.btn-primary.block{width:100%}
.btn-ghost{padding:10px 18px; border-radius:999px; border:1px solid var(--line); color:var(--text); font-size:14px; transition:.2s}
.btn-ghost:hover{border-color:var(--accent3); color:#fff}

/* ---------- Gate (password) ---------- */
.projects.gate, .projects.in{min-height:100vh}
.gate-wrap{position:relative; min-height:calc(100vh - 64px); display:grid; place-items:center; padding:40px 24px; overflow:hidden}
.gate-glow{position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(500px 380px at 50% 30%, rgba(124,92,255,.25), transparent 60%)}
.gate-card{position:relative; z-index:2; width:min(420px,100%); text-align:center; padding:40px 32px;
  border-radius:24px; background:linear-gradient(180deg,var(--panel),var(--panel2)); border:1px solid var(--line); box-shadow:var(--shadow)}
.lock{font-size:30px; margin-bottom:10px}
.lock svg{width:34px; height:34px; color:var(--accent2)}
.gate-card h1{font-size:26px; margin-bottom:8px}
.gate-card>p{color:var(--muted); font-size:14px; margin-bottom:22px}
.field{width:100%; padding:14px 16px; border-radius:12px; background:#0a0d15; border:1px solid var(--line); color:var(--text); font-size:15px; margin-bottom:14px; outline:none; transition:.2s}
.field:focus{border-color:var(--accent); box-shadow:0 0 0 3px rgba(0,212,255,.15)}
.field-wrap{position:relative; margin-bottom:14px}
.field-wrap .field{margin-bottom:0; padding-right:48px}
.pw-toggle{position:absolute; right:6px; top:50%; transform:translateY(-50%); background:none; border:none; color:var(--muted); cursor:pointer; padding:8px; line-height:0; display:grid; place-items:center; border-radius:8px}
.pw-toggle:hover{color:var(--text)}
.pw-toggle svg{width:20px; height:20px}
.pw-toggle .eye-off{display:none}
.pw-toggle.on .eye-on{display:none}
.pw-toggle.on .eye-off{display:block}
.alert{background:rgba(255,77,109,.12); border:1px solid rgba(255,77,109,.4); color:#ffb3c1; padding:10px 14px; border-radius:10px; font-size:13px; margin-bottom:14px}
.back{display:inline-block; margin-top:18px; color:var(--muted); font-size:13px}
.back:hover{color:var(--text)}

/* ---------- Dashboard ---------- */
.dash{padding:48px 0 80px; min-height:calc(100vh - 64px)}
.dash-head{display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-bottom:34px; padding-bottom:24px; border-bottom:1px solid var(--line)}
.dash-head h1{font-size:clamp(26px,4vw,38px)}
.muted{color:var(--muted); font-size:14px}
.empty{padding:48px; text-align:center; color:var(--muted); border:1px dashed var(--line); border-radius:var(--radius)}
.card.client::before{background:linear-gradient(90deg,var(--accent2),transparent 70%)}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line); padding:26px 0; color:var(--muted); font-size:13px}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap}
.site-footer a:hover{color:var(--text)}

/* ---------- Reveal ---------- */
.reveal{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1; transform:none}

/* ---------- Responsive ---------- */
@media (max-width:760px){
  .nav{gap:14px} .nav a:not(.nav-cta){display:none}
  .two-col{grid-template-columns:1fr}
  .section{padding:60px 0}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important; scroll-behavior:auto}
  .reveal{opacity:1; transform:none}
}

/* ---------- Event materials ---------- */
.dash.event .speaker{padding:20px 22px; border-radius:var(--radius); background:linear-gradient(180deg,var(--panel),var(--panel2)); border:1px solid var(--line); margin-bottom:16px}
.speaker-head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px}
.speaker-head h3{font-size:18px}
.empty-row{font-size:14px; opacity:.65; margin:0}
.files{list-style:none; display:grid; gap:8px; padding:0; margin:0}
.file{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:11px 14px; border-radius:12px; background:#0a0d15; border:1px solid var(--line)}
.file-name{font-size:14px; color:var(--text); word-break:break-word}
.file-actions{display:flex; gap:16px; white-space:nowrap}
.file-view{color:var(--accent)}
.file-view:hover{text-decoration:underline}
.file-dl{color:var(--accent2); font-weight:500}
.file-dl:hover{text-decoration:underline}
@media (max-width:600px){
  .file{flex-direction:column; align-items:flex-start; gap:8px}
}

/* ---------- Project cards as links + detail ---------- */
a.card{display:block; color:inherit; text-decoration:none}
.card-open{display:inline-block; margin-top:14px; font-size:13px; color:var(--accent); font-weight:500}
a.card:hover .card-open{text-decoration:underline}
.back-inline{color:var(--accent)}
.back-inline:hover{text-decoration:underline}
.dash.project .summary{margin-top:6px; max-width:760px}

/* ---------- Consulting / team ---------- */
.consulting{background:linear-gradient(180deg, rgba(124,92,255,.10), rgba(0,212,255,.05)); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-head.center{text-align:center; max-width:720px; margin-inline:auto}
.center-lead{margin-inline:auto; color:var(--muted)}
.people{display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; margin:38px 0}
.person{padding:30px 26px; border-radius:var(--radius); background:linear-gradient(180deg,var(--panel),var(--panel2)); border:1px solid var(--line); text-align:center}
.person-avatar{width:64px; height:64px; border-radius:50%; display:grid; place-items:center; margin:0 auto 16px; font-family:var(--display); font-weight:600; font-size:22px; color:#06080d; background:linear-gradient(120deg,var(--accent),var(--accent2)); box-shadow:0 10px 26px -10px var(--accent2)}
.person h3{font-size:20px; margin-bottom:14px}
.roles{list-style:none; display:flex; flex-direction:column; gap:7px; padding:0; margin:0}
.roles li{font-size:14px; color:var(--muted)}
.roles li:last-child{color:var(--accent); font-weight:600}
.consulting-cta{display:flex; align-items:center; justify-content:center; gap:22px; flex-wrap:wrap}
.consulting-mail{color:var(--muted); font-size:14px}
.consulting-mail:hover{color:var(--text)}

/* ---------- Workspace di progetto (w-) ---------- */
.ws .ph{vertical-align:-.12em}
.ws{padding:24px 0 70px}
.w-top{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:8px}
.w-proj{display:flex; align-items:center; gap:14px}
.w-code{font-family:var(--display); font-weight:700; font-size:15px; letter-spacing:.08em; color:#06080d; background:linear-gradient(120deg,var(--accent),var(--accent2)); padding:7px 12px; border-radius:10px}
.w-proj h1{font-size:22px}
.w-sub{font-size:12.5px; color:var(--muted)}
.w-top-r{display:flex; align-items:center; gap:10px}
.w-pill{font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--warn,#f4b860); border:1px solid rgba(244,184,96,.4); background:rgba(244,184,96,.1); padding:4px 10px; border-radius:999px}
.w-tabs{display:flex; gap:4px; border-bottom:1px solid var(--line); margin:14px 0 4px; overflow-x:auto}
.w-tab{padding:13px 15px; font-size:14px; color:var(--muted); background:none; border:none; border-bottom:2px solid transparent; cursor:pointer; white-space:nowrap; transition:.2s; font-family:var(--font); display:inline-flex; align-items:center; gap:8px}
.w-tab .ph{font-size:17px}
.w-tab:hover{color:var(--text)}
.w-tab.on{color:var(--text); border-bottom-color:var(--accent)}
.w-panel{display:none; padding-top:26px; animation:fade .35s ease}
.w-panel.on{display:block}
.w-card{background:linear-gradient(180deg,var(--panel),var(--panel2)); border:1px solid var(--line); border-radius:var(--radius); padding:22px}
.w-card h2{font-size:24px; margin-bottom:8px}
.w-lead{color:var(--muted); line-height:1.6; max-width:700px}
.w-sect{font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:12px; display:flex; align-items:center; gap:8px}
.w-muted{color:var(--muted); line-height:1.6}
.w-empty{padding:40px; text-align:center; color:var(--muted); border:1px dashed var(--line); border-radius:var(--radius)}
.w-stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:16px}
.w-stat{position:relative; background:#0a0d15; border:1px solid var(--line); border-radius:14px; padding:18px}
.w-si{position:absolute; top:16px; right:16px; color:var(--muted); font-size:18px; opacity:.55}
.w-n{font-family:var(--display); font-size:30px; font-weight:600; background:linear-gradient(120deg,#fff,#9fb0d6); -webkit-background-clip:text; background-clip:text; color:transparent}
.w-l{font-size:12.5px; color:var(--muted); margin-top:4px}
.w-ev{display:flex; gap:16px; align-items:flex-start}
.w-ev-date{flex:0 0 auto; width:66px; text-align:center; background:linear-gradient(160deg,rgba(124,92,255,.25),rgba(0,212,255,.12)); border:1px solid var(--line); border-radius:12px; padding:10px 0}
.w-d{font-family:var(--display); font-size:24px; font-weight:700; line-height:1}
.w-m{font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); margin-top:3px}
.w-ev h3{font-size:18px}
.w-meta{display:flex; gap:18px; flex-wrap:wrap; color:var(--muted); font-size:13px; margin:9px 0 11px}
.w-meta .ph{color:var(--accent)}
.w-chips{display:flex; gap:6px; flex-wrap:wrap}
.w-chip{font-size:12px; color:var(--muted); background:rgba(255,255,255,.04); border:1px solid var(--line); padding:4px 9px; border-radius:8px}
.w-spk{border:1px solid var(--line); border-radius:14px; overflow:hidden; background:#0a0d15; margin-bottom:10px}
.w-spk-h{display:flex; align-items:center; justify-content:space-between; padding:14px 18px}
.w-spk-h h3{font-size:16px; display:flex; align-items:center; gap:9px}
.w-spk-h h3 .ph{color:var(--muted)}
.w-c{font-size:12px; color:var(--muted)}
.w-files{border-top:1px solid var(--line); padding:6px 18px 14px}
.w-file{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:9px 0; border-bottom:1px solid rgba(255,255,255,.05)}
.w-file:last-child{border-bottom:none}
.w-fn{font-size:13.5px; display:flex; align-items:center; gap:9px}
.w-fn .ph{color:var(--accent2); font-size:17px}
.w-ftag{font-size:10px; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); border:1px solid var(--line); border-radius:5px; padding:1px 6px}
.w-fa a{font-size:13px; color:var(--accent); margin-left:14px; text-decoration:none; display:inline-flex; align-items:center; gap:5px}
.w-fa a:hover{text-decoration:underline}
.w-note{font-size:12.5px; color:var(--muted); background:rgba(124,92,255,.08); border:1px solid rgba(124,92,255,.25); border-radius:10px; padding:11px 14px; margin-top:8px; display:flex; gap:9px; align-items:center}
.w-note .ph{color:var(--accent2); font-size:18px}
.w-tlist{list-style:none; padding:0; margin:0}
.w-t{display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--line)}
.w-t .ph{font-size:20px; color:var(--muted); flex:0 0 auto}
.w-t.done .ph{color:var(--accent3,#37d67a)}
.w-txt{flex:1; font-size:14.5px}
.w-t.done .w-txt{color:var(--muted); text-decoration:line-through}
.w-who{font-size:11px; color:var(--muted); border:1px solid var(--line); border-radius:6px; padding:2px 8px}
.w-agenda{position:relative; margin-left:8px}
.w-agenda::before{content:""; position:absolute; left:71px; top:6px; bottom:6px; width:1px; background:var(--line)}
.w-day{display:flex; gap:18px; padding:10px 0}
.w-dt{flex:0 0 64px; text-align:right; padding-top:2px}
.w-dd{font-family:var(--display); font-size:18px; font-weight:600}
.w-wd{font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.08em}
.w-mark{flex:0 0 auto; width:14px; height:14px; border-radius:50%; margin-top:5px; position:relative; z-index:1; background:var(--panel); border:2px solid var(--accent)}
.w-day.evd .w-mark{border-color:var(--accent2); background:var(--accent2)}
.w-items{flex:1; display:grid; gap:8px}
.w-item{background:#0a0d15; border:1px solid var(--line); border-left:3px solid var(--accent); border-radius:10px; padding:11px 14px}
.w-item.event{border-left-color:var(--accent2)}
.w-item.todo{border-left-color:#37d67a}
.w-it-t{font-size:14px; font-weight:500}
.w-it-m{font-size:12.5px; color:var(--muted); margin-top:2px}
.w-legend{display:flex; gap:18px; font-size:12.5px; color:var(--muted); margin-top:18px; flex-wrap:wrap}
.w-legend i{display:inline-block; width:10px; height:10px; border-radius:3px; margin-right:6px; vertical-align:middle}
@media (max-width:600px){ .w-file{flex-direction:column; align-items:flex-start; gap:6px} }
.w-flash{margin-top:14px; padding:11px 16px; border-radius:12px; background:rgba(55,214,122,.1); border:1px solid rgba(55,214,122,.35); color:#9be7bd; font-size:14px; display:flex; align-items:center; gap:9px}
.w-badge{min-width:18px; height:18px; line-height:18px; text-align:center; font-size:11px; border-radius:9px; background:var(--accent2); color:#06080d; display:inline-block; padding:0 5px}
.w-ass-form{display:grid; gap:12px; max-width:560px}
.w-input{background:#0a0d15; border:1px solid var(--line); border-radius:10px; padding:11px 14px; color:var(--text); font-size:14px; outline:none; font-family:var(--font); width:100%}
.w-input:focus{border-color:var(--accent)}
textarea.w-input{resize:vertical}
.w-ass-form .btn-primary{justify-self:start; display:inline-flex; align-items:center; gap:8px}
.w-inbox{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.w-inb{display:flex; align-items:center; gap:12px; padding:11px 14px; background:#0a0d15; border:1px solid var(--line); border-radius:10px; flex-wrap:wrap}
.w-inb-tag{font-size:10px; text-transform:uppercase; letter-spacing:.05em; color:var(--accent2); border:1px solid rgba(124,92,255,.4); border-radius:5px; padding:2px 7px}
.w-inb-txt{flex:1; font-size:14px; min-width:160px}
.w-inb-meta{font-size:12px; color:var(--muted)}
/* editing condiviso */
.w-ein{width:100%; background:transparent; border:1px solid transparent; border-radius:8px; padding:7px 9px; color:var(--text); font-family:var(--font); font-size:14.5px; outline:none; transition:.15s; margin:0}
.w-ein:hover{border-color:var(--line); background:rgba(255,255,255,.03)}
.w-ein:focus{border-color:var(--accent); background:rgba(0,212,255,.06)}
textarea.w-ein{resize:vertical; line-height:1.55}
.w-ein-h2{font-family:var(--display); font-size:23px; font-weight:600; letter-spacing:-.02em}
.w-ein-h3{font-family:var(--display); font-size:18px; font-weight:600}
.w-edit-hint{font-size:12px; color:var(--muted); opacity:.55; display:flex; align-items:center; gap:6px; margin-top:10px}
.w-edrow{display:flex; gap:10px; flex-wrap:wrap; margin:12px 0}
.w-edlab{display:inline-flex; align-items:center; gap:7px; color:var(--muted); font-size:13px; background:#0a0d15; border:1px solid var(--line); border-radius:10px; padding:2px 10px}
.w-edlab .w-ein{width:auto; border:none}
.w-edlab .w-ein:hover,.w-edlab .w-ein:focus{background:transparent}
.w-edlab input[type=date]{color-scheme:dark}
.w-edtodo{display:flex; align-items:center; gap:10px; padding:7px 0; border-bottom:1px solid var(--line)}
.w-edcheck{appearance:none; width:20px; height:20px; border:1.5px solid var(--muted); border-radius:6px; cursor:pointer; flex:0 0 auto; position:relative; transition:.2s}
.w-edcheck:checked{background:linear-gradient(120deg,var(--accent),#37d67a); border-color:transparent}
.w-edcheck:checked::after{content:"\2713"; position:absolute; inset:0; display:grid; place-items:center; color:#06080d; font-size:13px; font-weight:700}
.w-edtodo .w-ein{flex:1}
.w-edwho{flex:0 0 120px; max-width:120px}
.w-del{flex:0 0 auto; background:none; border:none; color:var(--muted); font-size:20px; line-height:1; cursor:pointer; padding:2px 8px; border-radius:8px; transition:.15s}
.w-del:hover{color:#ff6b81; background:rgba(255,77,109,.1)}
.add{font-size:13px; color:var(--accent); background:none; border:1px dashed rgba(0,212,255,.4); border-radius:10px; padding:11px 14px; cursor:pointer; transition:.2s; display:inline-flex; align-items:center; justify-content:center; gap:8px; margin-top:14px}
.add:hover{background:rgba(0,212,255,.06)}
.w-savebar{position:sticky; bottom:0; display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-top:24px; padding:14px 18px; border-radius:14px; background:linear-gradient(180deg,rgba(17,21,31,.96),rgba(11,14,22,.98)); border:1px solid var(--line); backdrop-filter:blur(10px); box-shadow:0 -10px 30px -16px rgba(0,0,0,.7)}
.w-savebar .w-muted{font-size:12.5px; display:inline-flex; align-items:center; gap:8px}
.w-savebar .btn-primary{display:inline-flex; align-items:center; gap:8px}
.w-savebar .btn-primary:disabled{opacity:.4; cursor:default; box-shadow:none; transform:none}
.w-hist{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.w-hrow{display:flex; align-items:center; gap:14px; padding:11px 14px; background:#0a0d15; border:1px solid var(--line); border-radius:10px; flex-wrap:wrap}
.w-hwhen{font-size:14px; display:inline-flex; align-items:center; gap:8px}
.w-hby{font-size:12.5px; color:var(--muted); flex:1}
.w-hform{margin:0}
.w-hform .btn-ghost{display:inline-flex; align-items:center; gap:7px}
/* assistente chat */
.w-chat{display:flex; flex-direction:column; height:540px; background:linear-gradient(180deg,var(--panel),var(--panel2)); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden}
.w-chat-h{display:flex; align-items:center; gap:11px; padding:15px 18px; border-bottom:1px solid var(--line)}
.w-chat-av{width:36px; height:36px; border-radius:10px; display:grid; place-items:center; background:linear-gradient(120deg,var(--accent),var(--accent2)); color:#06080d; font-size:18px}
.w-chat-h h3{font-size:16px}
.w-chat-st{font-size:12px; color:#37d67a; display:flex; align-items:center; gap:6px}
.w-chat-st .ph{font-size:11px}
.w-msgs{flex:1; overflow:auto; padding:18px; display:flex; flex-direction:column; gap:12px}
.w-msg{max-width:80%; padding:11px 14px; border-radius:14px; font-size:14px; line-height:1.5; white-space:pre-wrap; word-wrap:break-word}
.w-msg.bot{align-self:flex-start; background:rgba(124,92,255,.12); border:1px solid rgba(124,92,255,.25); border-bottom-left-radius:4px}
.w-msg.me{align-self:flex-end; background:#0a0d15; border:1px solid var(--line); border-bottom-right-radius:4px}
.w-msg.typing{color:var(--muted); font-style:italic}
.w-chat-in{display:flex; align-items:center; gap:10px; padding:13px 15px; border-top:1px solid var(--line)}
.w-chat-in input{flex:1; background:#0a0d15; border:1px solid var(--line); border-radius:12px; padding:12px 15px; color:var(--text); font-size:14px; outline:none}
.w-chat-in input:focus{border-color:var(--accent)}
.w-send{width:42px; height:42px; border-radius:12px; border:none; background:linear-gradient(120deg,var(--accent),var(--accent2)); color:#06080d; cursor:pointer; font-size:18px; flex:0 0 auto; display:grid; place-items:center}
.w-send:disabled{opacity:.4; cursor:default}
.w-chat-note{font-size:12px; color:var(--warn,#f4b860); padding:0 16px 12px; display:flex; align-items:center; gap:7px}
