/* ─── TOKENS ─── */
:root{
  --bg:#07070f;
  --s1:#0e0e1c;
  --s2:#13131f;
  --border:rgba(255,255,255,.06);
  --p:#8b5cf6;
  --p2:#a78bfa;
  --c:#22d3ee;
  --c2:#67e8f9;
  --text:#dde1f0;
  --muted:#4b4b6e;
  --white:#fff;
  --surface: #0f0f1a;
  --surface2: #14141f;
  --border: rgba(255,255,255,0.07);
  --purple: #a855f7;
  --cyan: #06b6d4;
  --pink: #ec4899;
  --text: #e2e2f0;
  --muted: #5a5a7a;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Cabinet Grotesk',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:'Clash Display',sans-serif;letter-spacing:-.02em}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#1e1e35;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--p)}

/* grain */
body::after{content:'';position:fixed;inset:0;opacity:.022;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none;z-index:9998}

/* ─── PAGES ─── */
.page{min-height:100vh}
.page.active{display:block}

/* ─── NAV ─── */
nav{position:fixed;top:0;left:0;right:0;z-index:300;height:68px;display:flex;align-items:center;background:rgba(7,7,15,.8);backdrop-filter:blur(24px);border-bottom:1px solid var(--border)}
.nav-wrap{max-width:1100px;margin:0 auto;padding:0 2rem;width:100%;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Clash Display',sans-serif;font-size:1.05rem;font-weight:700;color:var(--white);cursor:pointer;display:flex;align-items:center;gap:8px;text-decoration:none;letter-spacing:-.01em}
.logo img{height:30px;width:auto;object-fit:contain}
.logo-dot{width:6px;height:6px;border-radius:50%;background:var(--c);box-shadow:0 0 8px var(--c);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.nav-right{display:flex;align-items:center;gap:.25rem}
.nav-link{color:var(--muted);font-size:.85rem;font-weight:500;padding:.45rem .85rem;border-radius:8px;cursor:pointer;transition:all .2s;border:none;background:none;font-family:'Cabinet Grotesk',sans-serif;text-decoration:none}
.nav-link:hover{color:var(--white);background:rgba(255,255,255,.05)}
.nav-cta{color:var(--c)!important;border:1px solid rgba(34,211,238,.35)!important;border-radius:99px!important;padding:.45rem 1.1rem!important;box-shadow:0 0 18px rgba(34,211,238,.08)}
.nav-cta:hover{background:var(--c)!important;color:#07070f!important;box-shadow:0 0 28px rgba(34,211,238,.3)!important}
.nav-admin{font-size:.72rem!important;border:1px solid var(--border)!important;border-radius:7px!important}

/* ─── BTNS ─── */
.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.8rem 1.75rem;border-radius:12px;font-family:'Cabinet Grotesk',sans-serif;font-weight:700;font-size:.88rem;cursor:pointer;transition:all .25s;border:none;text-decoration:none}
.btn-grad{background:linear-gradient(135deg,var(--p),var(--c));color:#fff;box-shadow:0 6px 28px rgba(139,92,246,.3)}
.btn-grad:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(139,92,246,.45)}
.btn-ghost{background:transparent;color:var(--white);border:1px solid var(--border)}
.btn-ghost:hover{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.04)}
.btn-sm{padding:.5rem .95rem!important;font-size:.78rem!important;border-radius:9px!important}
.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626)!important;box-shadow:none!important}

/* ─── HERO ─── */
#hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding-top:68px}
.orb{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none}
.hero-inner{text-align:center;max-width:760px;padding:2rem;position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);padding:.35rem .95rem;border-radius:99px;margin-bottom:2rem;animation:up .9s ease both}
.eyebrow::before{content:'';width:5px;height:5px;background:var(--c);border-radius:50%;box-shadow:0 0 7px var(--c);animation:pulse 2s ease infinite}
.hero-title{font-size:clamp(3.5rem,9vw,6.8rem);font-weight:700;line-height:.9;letter-spacing:-.05em;color:var(--white);margin-bottom:1.5rem;animation:up .9s .12s ease both}
.grad-text{background:linear-gradient(120deg,var(--p2),var(--c2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:clamp(.95rem,2vw,1.2rem);color:var(--muted);margin-bottom:2.5rem;min-height:2rem;animation:up .9s .25s ease both;display:flex;align-items:center;justify-content:center;gap:.4rem}
#tw{color:var(--c);font-weight:700}
.tw-cursor{color:var(--c);animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-actions{display:flex;gap:.875rem;justify-content:center;flex-wrap:wrap;animation:up .9s .38s ease both}
@keyframes up{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* ─── SECTIONS ─── */
.sec{padding:5.5rem 2rem}
.sec-inner{max-width:1100px;margin:0 auto}
.sec-label{font-size:.65rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--p2);margin-bottom:.6rem;display:block}
.sec-title{font-size:clamp(1.6rem,3.5vw,2.3rem);font-weight:700;color:var(--white);line-height:1.1}
.sec-sub{color:var(--muted);font-size:.9rem;margin-top:.4rem}

/* ─── ABOUT ─── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:center}
@media(max-width:768px){.about-grid{grid-template-columns:1fr;gap:2.5rem}}
.about-body p{color:var(--muted);line-height:1.85;font-size:.95rem;margin-bottom:1.1rem}
.about-img-wrap{position:relative}
.about-img-wrap::before{content:'';position:absolute;inset:-3px;background:linear-gradient(135deg,var(--p),var(--c));border-radius:22px;z-index:0;opacity:.35}
.about-img-wrap img{position:relative;z-index:1;width:100%;height:440px;object-fit:cover;border-radius:20px;filter:grayscale(10%);transition:filter .5s}
.about-img-wrap:hover img{filter:grayscale(0%)}

/* ABOUT */
.about-text p{color:var(--muted);line-height:1.85;font-size:.975rem;margin-bottom:1.25rem}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem}
.stat-card{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:1.25rem;transition:border-color .3s}
.stat-card:hover{border-color:rgba(168,85,247,.3)}
.stat-num{font-family:'Syne',sans-serif;font-size:1.9rem;font-weight:800;color:white;line-height:1;margin-bottom:.2rem}
.stat-num span{color:var(--purple)}
.stat-lbl{font-size:.78rem;color:var(--muted)}
.about-image{position:relative}
.about-image::before{content:'';position:absolute;inset:-2px;background:linear-gradient(135deg,var(--purple),var(--cyan));border-radius:20px;z-index:0;opacity:.4}
.about-image img{position:relative;z-index:1;width:100%;height:650px;object-fit:cover;border-radius:18px;filter:grayscale(15%);transition:filter .5s}
.about-image:hover img{filter:grayscale(0%)}


/* ─── CATEGORY CARDS ─── */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
@media(max-width:768px){.cat-grid{grid-template-columns:1fr}}
.cat-card{position:relative;border-radius:18px;overflow:hidden;cursor:pointer;aspect-ratio:4/3;border:1px solid var(--border);transition:transform .45s cubic-bezier(.16,1,.3,1),box-shadow .45s}
.cat-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px rgba(139,92,246,.3)}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.16,1,.3,1),filter .4s;filter:brightness(.45) saturate(.7)}
.cat-card:hover img{transform:scale(1.1);filter:brightness(.28) saturate(.6)}
.cat-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.625rem;background:linear-gradient(to top,rgba(7,7,15,.98) 0%,rgba(7,7,15,.15) 55%,transparent 100%);transition:background .4s}
.cat-card:hover .cat-overlay{background:linear-gradient(to top,rgba(7,7,15,1) 0%,rgba(7,7,15,.7) 60%,rgba(139,92,246,.06) 100%)}
.cat-tag{font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--c);margin-bottom:.45rem;opacity:0;transform:translateY(7px);transition:all .3s .05s}
.cat-card:hover .cat-tag{opacity:1;transform:translateY(0)}
.cat-title{font-family:'Clash Display',sans-serif;font-size:1.45rem;font-weight:700;color:var(--white);margin-bottom:.35rem}
.cat-sub{font-size:.82rem;color:var(--muted);margin-bottom:.875rem;transition:color .3s}
.cat-card:hover .cat-sub{color:rgba(255,255,255,.45)}
.cat-arrow{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:700;color:var(--p2);opacity:0;transform:translateY(7px);transition:all .3s .1s}
.cat-card:hover .cat-arrow{opacity:1;transform:translateY(0)}
.cat-count{position:absolute;top:.875rem;right:.875rem;background:rgba(7,7,15,.75);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:99px;padding:.2rem .65rem;font-size:.66rem;font-weight:700;color:var(--c);z-index:2;transition:all .3s}
.cat-card:hover .cat-count{background:rgba(139,92,246,.2);border-color:rgba(139,92,246,.45);color:var(--p2)}

/* ─── CONTACT ─── */
.contact-box{background:var(--s2);border:1px solid var(--border);border-radius:22px;padding:2.25rem;max-width:620px;margin:0 auto}
.f-group{margin-bottom:.875rem}
.f-group label{display:block;font-size:.75rem;font-weight:500;color:var(--muted);margin-bottom:.4rem;letter-spacing:.05em}
.f-group input,.f-group textarea,.f-group select{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:.7rem .95rem;color:var(--white);font-family:'Cabinet Grotesk',sans-serif;font-size:.875rem;transition:border-color .2s,box-shadow .2s;outline:none;appearance:none}
.f-group input:focus,.f-group textarea:focus,.f-group select:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(139,92,246,.12)}
.f-group textarea{resize:vertical;min-height:110px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:.875rem;margin-bottom:.875rem}
@media(max-width:520px){.f-row{grid-template-columns:1fr}}
.socials{display:flex;justify-content:center;gap:1rem;margin-top:2rem}
.soc{width:42px;height:42px;background:var(--s2);border:1px solid var(--border);border-radius:11px;display:flex;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;font-size:1rem;transition:all .2s}
.soc:hover{color:var(--white);border-color:rgba(255,255,255,.18);transform:translateY(-3px)}

/* ─── PROJECTS LIST PAGE ─── */
#proj-page{padding-top:68px;background:var(--bg)}
.proj-header{max-width:1100px;margin:0 auto;padding:3.5rem 2rem 1.5rem}
.back-btn{display:inline-flex;align-items:center;gap:.4rem;color:var(--muted);font-size:.82rem;font-weight:500;cursor:pointer;border:none;background:none;font-family:'Cabinet Grotesk',sans-serif;margin-bottom:1.75rem;transition:color .2s;padding:0}
.back-btn:hover{color:var(--white)}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.1rem;max-width:1100px;margin:0 auto;padding:1rem 2rem 5rem}
.proj-card{position:relative;border-radius:15px;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--border);background:var(--s1);cursor:pointer;transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s}
.proj-card:hover{transform:translateY(-5px) scale(1.01);box-shadow:0 20px 50px rgba(0,0,0,.5),0 0 0 1px rgba(139,92,246,.25)}
.proj-card img{width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.proj-card:hover img{transform:scale(1.08)}
.proj-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,15,.97) 0%,rgba(7,7,15,.3) 50%,rgba(139,92,246,.04) 100%);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:1.375rem}
.proj-card:hover .proj-card-overlay{opacity:1}
.proj-card-title{font-family:'Clash Display',sans-serif;font-size:1.1rem;font-weight:600;color:var(--white);margin-bottom:.25rem;transform:translateY(8px);transition:transform .28s .04s}
.proj-card:hover .proj-card-title{transform:translateY(0)}
.proj-card-date{font-size:.7rem;color:var(--c);font-weight:600;letter-spacing:.07em;transform:translateY(8px);transition:transform .28s .09s}
.proj-card:hover .proj-card-date{transform:translateY(0)}
.proj-no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:2.5rem}
.empty-state{text-align:center;padding:5rem 2rem;color:var(--muted);grid-column:1/-1}
.empty-state i{font-size:2.5rem;display:block;margin-bottom:.875rem;opacity:.3}
.empty-state p{font-size:.875rem;line-height:1.7}

/* ─── PROJECT DETAIL PAGE (Patreon-style) ─── */
#detail-page{padding-top:68px;background:var(--bg);min-height:100vh}
.detail-hero{position:relative;height:400px;overflow:hidden}
.detail-hero img{width:100%;height:100%;object-fit:cover;filter:brightness(.4)}
.detail-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 20%,rgba(7,7,15,.7) 60%,var(--bg) 100%)}
.detail-hero-content{position:absolute;bottom:0;left:0;right:0;max-width:820px;margin:0 auto;padding:2.5rem 2rem}
.detail-cat-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--c);border:1px solid rgba(34,211,238,.3);background:rgba(34,211,238,.08);padding:.3rem .75rem;border-radius:99px;margin-bottom:.875rem}
.detail-title{font-size:clamp(2rem,5vw,3.2rem);font-weight:700;color:var(--white);line-height:1.05;margin-bottom:.5rem}
.detail-meta{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:.875rem;flex-wrap:wrap}
.detail-meta span{display:flex;align-items:center;gap:.3rem}
.detail-meta a{color:var(--c);text-decoration:none;display:flex;align-items:center;gap:.3rem;transition:opacity .2s}
.detail-meta a:hover{opacity:.75}

/* detail body */
.detail-body{max-width:820px;margin:0 auto;padding:3rem 2rem 6rem}
.detail-body p{color:var(--muted);line-height:1.9;font-size:1rem;margin-bottom:1.25rem}
.detail-body h2{font-family:'Clash Display',sans-serif;font-size:1.5rem;font-weight:700;color:var(--white);margin:2.5rem 0 .875rem}
.detail-body h3{font-family:'Clash Display',sans-serif;font-size:1.2rem;font-weight:600;color:var(--white);margin:2rem 0 .625rem}
/* inline images */
.img-block{margin:2rem 0;border-radius:14px;overflow:hidden}
.img-block img{width:100%;height:auto;display:block;border-radius:14px}
.img-block.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.img-block.cols-2 img{border-radius:10px;height:240px;object-fit:cover}
.img-caption{font-size:.78rem;color:var(--muted);text-align:center;margin-top:.5rem;font-style:italic}

/* ─── ADMIN ─── */
#admin-page{padding-top:68px;background:var(--bg);min-height:100vh}
#login-screen{min-height:calc(100vh - 68px);display:flex;align-items:center;justify-content:center;padding:2rem}
.login-card{width:100%;max-width:400px;background:var(--s1);border:1px solid var(--border);border-radius:22px;padding:2.25rem;box-shadow:0 40px 80px rgba(0,0,0,.5),0 0 0 1px rgba(139,92,246,.08)}
.login-icon-wrap{width:52px;height:52px;background:linear-gradient(135deg,var(--p),var(--c));border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;margin:0 auto .875rem}
.login-card h2{font-size:1.3rem;font-weight:700;color:var(--white);text-align:center}
.login-card p{font-size:.82rem;color:var(--muted);text-align:center;margin-top:.2rem;margin-bottom:1.75rem}
.login-err{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:9px;padding:.65rem .9rem;font-size:.8rem;color:#f87171;margin-bottom:.875rem;display:none;align-items:center;gap:.4rem}
#dash-screen{display:none}
.admin-layout{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 68px)}
@media(max-width:860px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{display:none}}
.admin-sidebar{background:var(--s1);border-right:1px solid var(--border);padding:1.75rem 1rem;position:sticky;top:68px;height:calc(100vh - 68px);overflow-y:auto}
.sb-label{font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);padding:0 .65rem;margin-bottom:.65rem}
.sb-btn{display:flex;align-items:center;gap:.65rem;padding:.575rem .65rem;border-radius:9px;font-size:.845rem;font-weight:500;color:var(--muted);width:100%;border:none;background:none;cursor:pointer;transition:all .2s;margin-bottom:.12rem;text-align:left;font-family:'Cabinet Grotesk',sans-serif}
.sb-btn:hover{color:var(--white);background:rgba(255,255,255,.05)}
.sb-btn.active{color:var(--white);background:rgba(139,92,246,.15)}
.sb-btn.active .sb-icon{color:var(--p)}
.sb-icon{width:16px;text-align:center;color:var(--muted)}
.sb-div{height:1px;background:var(--border);margin:.875rem 0}
.admin-main{padding:2.25rem;overflow-y:auto}
.admin-panel, .panel-messages{display:none}
.admin-panel.active,.panel-messages.active{display:block}
.dash-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.75rem;flex-wrap:wrap;gap:.875rem}
.dash-hdr h1{font-size:1.6rem;font-weight:700;color:var(--white)}
.dash-hdr p{font-size:.82rem;color:var(--muted);margin-top:.2rem}
.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.875rem;margin-bottom:1.75rem}
@media(max-width:560px){.dash-stats{grid-template-columns:1fr}}
.d-stat{background:var(--s1);border:1px solid var(--border);border-radius:14px;padding:1.25rem;display:flex;align-items:center;gap:.875rem;transition:border-color .3s}
.d-stat:hover{border-color:rgba(139,92,246,.3)}
.d-stat-ico{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.d-stat-n{font-family:'Clash Display',sans-serif;font-size:1.6rem;font-weight:700;color:var(--white);line-height:1}
.d-stat-l{font-size:.75rem;color:var(--muted);margin-top:.2rem}
.post-row{display:grid;grid-template-columns:56px 1fr auto auto;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border);transition:background .2s}
.post-row:last-child{border-bottom:none}
.post-row:hover{background:rgba(255,255,255,.02)}
.posts-tbl{background:var(--s1);border:1px solid var(--border);border-radius:18px;overflow:hidden}
.tbl-hdr{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.375rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.875rem}
.tbl-hdr h3{font-size:.9rem;font-weight:700;color:var(--white)}
.srch-wrap{position:relative}
.srch-wrap i{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.72rem}
.srch{background:var(--bg);border:1px solid var(--border);border-radius:9px;padding:.45rem .8rem .45rem 2.1rem;color:var(--white);font-family:'Cabinet Grotesk',sans-serif;font-size:.8rem;outline:none;width:200px;transition:border-color .2s}
.srch:focus{border-color:var(--p)}
.p-row{display:grid;grid-template-columns:52px 1fr auto auto;align-items:center;gap:.875rem;padding:.9rem 1.375rem;border-bottom:1px solid var(--border);transition:background .2s}
.p-row:last-child{border-bottom:none}
.p-row:hover{background:rgba(255,255,255,.02)}
.p-thumb{width:52px;height:40px;border-radius:7px;background:var(--s2);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:1rem;flex-shrink:0;overflow:hidden}
.p-thumb img{width:100%;height:100%;object-fit:cover}
.p-name{font-size:.845rem;font-weight:600;color:var(--white);margin-bottom:.2rem}
.p-badge{display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.13rem .45rem;border-radius:99px;background:rgba(139,92,246,.15);color:var(--p2);border:1px solid rgba(139,92,246,.2)}
.p-date{font-size:.73rem;color:var(--muted);white-space:nowrap}
.p-acts{display:flex;gap:.4rem}
.ico-btn{width:30px;height:30px;border-radius:7px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.75rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.ico-btn:hover{background:rgba(255,255,255,.05);color:var(--white)}
.ico-btn.edit:hover{background:rgba(139,92,246,.12);color:var(--p2);border-color:rgba(139,92,246,.3)}
.ico-btn.del:hover{background:rgba(239,68,68,.1);color:#f87171;border-color:rgba(239,68,68,.3)}
.filter-pills{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1.375rem}
.pill{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .8rem;border-radius:7px;font-size:.75rem;font-weight:600;color:var(--muted);border:1px solid var(--border);background:none;cursor:pointer;transition:all .2s;font-family:'Cabinet Grotesk',sans-serif}
.pill.active{color:var(--white);background:rgba(139,92,246,.15);border-color:rgba(139,92,246,.3)}
.pill:hover:not(.active){color:var(--white);background:rgba(255,255,255,.05)}

/* EDITOR */
.ed-grid{display:grid;grid-template-columns:1fr 300px;gap:1.375rem;align-items:start}
@media(max-width:860px){.ed-grid{grid-template-columns:1fr}}
.ed-card{background:var(--s1);border:1px solid var(--border);border-radius:18px;padding:1.625rem;margin-bottom:1.375rem}
.ed-card:last-child{margin-bottom:0}
.ed-card-title{font-size:.82rem;font-weight:700;color:var(--white);margin-bottom:1.1rem;padding-bottom:.875rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.4rem}
.ed-card-title i{color:var(--p2)}
.cat-sel{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem}
.cat-opt{padding:.65rem .4rem;border-radius:9px;border:1px solid var(--border);background:var(--bg);color:var(--muted);font-size:.75rem;font-weight:600;text-align:center;cursor:pointer;transition:all .2s;font-family:'Cabinet Grotesk',sans-serif}
.cat-opt:hover{border-color:rgba(139,92,246,.3);color:var(--white)}
.cat-opt.sel{border-color:var(--p);background:rgba(139,92,246,.12);color:var(--p2)}
.upload-area{border:2px dashed var(--border);border-radius:12px;padding:1.75rem;text-align:center;cursor:pointer;transition:all .3s;background:var(--bg);position:relative;overflow:hidden;min-height:130px;display:flex;align-items:center;justify-content:center;flex-direction:column}
.upload-area:hover,.upload-area.drag{border-color:var(--p);background:rgba(139,92,246,.05)}
.upload-area input{position:absolute;inset:0;opacity:0;cursor:pointer;font-size:0}
.up-prev{width:100%;max-height:170px;object-fit:cover;border-radius:8px;display:none}
.up-icon{font-size:1.8rem;color:var(--muted);margin-bottom:.625rem}
.up-text{font-size:.82rem;color:var(--muted)}
.up-sub{font-size:.7rem;color:var(--muted);opacity:.6;margin-top:.2rem}
.pv-card{position:sticky;top:1.375rem}
.pv-mini{border-radius:11px;overflow:hidden;border:1px solid var(--border);background:var(--s2);aspect-ratio:4/3;position:relative;margin-bottom:.875rem}
.pv-mini img{width:100%;height:100%;object-fit:cover;display:none}
.pv-noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:1.8rem}
.pv-ttl{font-size:.9rem;font-weight:700;color:var(--white);margin-bottom:.2rem}
.pv-meta{font-size:.7rem;color:var(--c)}

/* ─── RICH CONTENT EDITOR ─── */
.rich-editor{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:1.375rem}
.rich-toolbar{display:flex;align-items:center;gap:.2rem;padding:.625rem .875rem;border-bottom:1px solid var(--border);flex-wrap:wrap;background:var(--s2)}
.tb-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--muted);font-size:.78rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;font-family:'Cabinet Grotesk',sans-serif}
.tb-btn:hover{background:rgba(255,255,255,.08);color:var(--white)}
.tb-btn.active{background:rgba(139,92,246,.2);color:var(--p2)}
.tb-sep{width:1px;height:18px;background:var(--border);margin:0 .15rem}
.tb-btn-text{width:auto;padding:0 .5rem;font-size:.7rem;font-weight:600}
.rich-area{min-height:250px;padding:1.125rem;color:var(--text);font-family:'Cabinet Grotesk',sans-serif;font-size:.92rem;line-height:1.85;outline:none;white-space:pre-wrap}
.rich-area:empty::before{content:'Scrivi il contenuto del progetto...';color:var(--muted);pointer-events:none}
/* image blocks in editor */
.img-insert{border:1px solid var(--border);border-radius:10px;overflow:hidden;margin:.5rem 0;position:relative;background:var(--s2)}
.img-insert.cols-2-wrap{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;padding:.5rem}
.img-insert img{width:100%;height:180px;object-fit:cover;display:block}
.img-insert.cols-2-wrap img{border-radius:7px;height:150px}
.img-insert-remove{position:absolute;top:.4rem;right:.4rem;width:24px;height:24px;border-radius:6px;background:rgba(239,68,68,.85);color:#fff;border:none;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;z-index:2}
.img-insert-label{font-size:.68rem;color:var(--muted);padding:.3rem .5rem;text-align:center}

/* mobile admin tabs */
.mob-tabs{display:none;background:var(--s1);border-bottom:1px solid var(--border);padding:.875rem 1.375rem;gap:.4rem;flex-wrap:wrap;align-items:center}
@media(max-width:860px){.mob-tabs{display:flex}}

/* toast */
.toast{position:fixed;bottom:1.75rem;right:1.75rem;background:var(--s1);border:1px solid var(--border);border-radius:12px;padding:.8rem 1.25rem;display:flex;align-items:center;gap:.65rem;box-shadow:0 20px 50px rgba(0,0,0,.45);z-index:9999;transform:translateY(18px);opacity:0;transition:all .3s;pointer-events:none;font-size:.85rem;color:var(--white)}
.toast.show{transform:translateY(0);opacity:1}
.toast i{color:#22c55e}
.toast.err i{color:#ef4444}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(5px);z-index:600;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-bg.open{opacity:1;pointer-events:auto}
.modal{background:var(--s1);border:1px solid var(--border);border-radius:18px;padding:1.75rem;width:100%;max-width:440px;transform:scale(.95);opacity:0;transition:all .3s}
.modal-bg.open .modal{transform:scale(1);opacity:1}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}
.modal-hdr h3{font-size:1.05rem;font-weight:700;color:var(--white)}
.modal-x{background:none;border:none;color:var(--muted);font-size:1rem;cursor:pointer;line-height:1;transition:color .2s}
.modal-x:hover{color:var(--white)}

/* reveal */
.rv{opacity:0;transform:translateY(22px);transition:all .65s cubic-bezier(.16,1,.3,1)}
.rv.on{opacity:1;transform:translateY(0)}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}

footer{background:var(--s1);border-top:1px solid var(--border);padding:1.5rem;text-align:center;font-size:.75rem;color:var(--muted)}
.icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.78rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.icon-btn:hover{background:rgba(255,255,255,.05);color:white}
.icon-btn.danger:hover{background:rgba(239,68,68,.1);color:#f87171;border-color:rgba(239,68,68,.3)}
.icon-btn.edit:hover{background:rgba(168,85,247,.1);color:var(--purple);border-color:rgba(168,85,247,.3)}