/* Aijoo — feuille de style servie au navigateur */
:root{
  --coral:#EF6C4D; --coral-deep:#D5512F; --coral-soft:#F6916F; --mari:#F2A93B;
  --cream:#FBF7F1; --paper:#FFFFFF; --blush:#FBEDE6; --sand:#F4ECDF; --peach:#FDF1E8;
  --ink:#2A2622; --ink-soft:#6B6157; --ink-faint:#9C9387;
  --line:#EEE5D8; --line-soft:#F4ECDF;
  --ok:#5C7A3F; --warn:#D5512F;
  --shadow-sm:0 1px 2px rgba(42,38,34,.05);
  --shadow-md:0 12px 36px -8px rgba(42,38,34,.16);
  --shadow-lg:0 28px 70px -20px rgba(213,81,47,.30);
  --r-lg:24px; --r-md:16px; --r-sm:12px;
  --display:"Gabarito",system-ui,sans-serif; --sans:"Figtree",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);height:100vh;overflow:hidden;-webkit-font-smoothing:antialiased;
  background:var(--cream);position:relative}
/* atmosphere: warm mesh + grain */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60% 50% at 88% -6%, #FCE4D8 0, transparent 60%),
    radial-gradient(50% 45% at -8% 108%, #FBEAD0 0, transparent 60%),
    radial-gradient(40% 40% at 50% 50%, #FDFAF5 0, transparent 70%);}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea{font-family:inherit}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#E4D8C6;border-radius:99px}::-webkit-scrollbar-track{background:transparent}
h1,h2,h3{font-family:var(--display)}
.mark{background:linear-gradient(transparent 62%, var(--blush) 62%);padding:0 .06em}

.app{display:grid;grid-template-columns:78px 1fr;height:100vh;position:relative;z-index:1}

/* ---------- blinking eyes (the brand, alive) ---------- */
.eyes{display:inline-flex;align-items:center;gap:.16em;line-height:0}
.eyes .eye{width:var(--s,20px);height:var(--s,20px);border-radius:50%;position:relative;transform-origin:center;
  animation:blink 6s infinite}
.eyes .eye.ring{animation-delay:.05s}
.eyes .eye.solid{background:var(--coral)}
.eyes .eye.ring{background:transparent;box-shadow:inset 0 0 0 calc(var(--s,20px)*.18) var(--ink)}
.eyes .eye b{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:50%}
.eyes .eye.solid b{width:36%;height:36%;background:var(--cream)}
.eyes .eye.ring b{width:34%;height:34%;background:var(--coral)}
.eyes.ink .eye.ring{box-shadow:inset 0 0 0 calc(var(--s,20px)*.18) var(--cream)}
.eyes.ink .eye.ring b{background:var(--mari)}
@keyframes blink{0%,93%,100%{transform:scaleY(1)}96.5%{transform:scaleY(.08)}}

/* ---------- rail ---------- */
.rail{background:linear-gradient(180deg,#322D28,#241F1B);display:flex;flex-direction:column;align-items:center;padding:16px 0 14px;gap:6px;
  box-shadow:6px 0 30px -18px rgba(0,0,0,.5)}
.rail .brand{width:48px;height:48px;border-radius:15px;background:#3B352F;display:grid;place-items:center;margin-bottom:16px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
.rail .nav{flex:1;display:flex;flex-direction:column;gap:7px}
.rail .nav button{width:50px;height:48px;border-radius:15px;display:grid;place-items:center;color:#9D9183;transition:.18s cubic-bezier(.2,.7,.2,1);position:relative}
.rail .nav button svg{width:21px;height:21px;transition:.18s}
.rail .nav button:hover{background:rgba(255,255,255,.06);color:#F2E9DB}
.rail .nav button:hover svg{transform:scale(1.08)}
.rail .nav button.active{background:var(--coral);color:#fff;box-shadow:0 8px 20px -6px rgba(239,108,77,.7)}
.rail .nav button.active::before{content:"";position:absolute;left:-14px;width:4px;height:22px;border-radius:99px;background:var(--coral)}
.rail .nav button .badge{position:absolute;top:5px;right:5px;background:var(--mari);color:var(--ink);font-size:.6rem;font-weight:800;border-radius:99px;min-width:16px;height:16px;display:grid;place-items:center;padding:0 3px;box-shadow:0 0 0 2px #241F1B}
.rail .me{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--mari),var(--coral));display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:800;font-size:1.05rem;box-shadow:0 6px 16px -6px rgba(239,108,77,.8)}

.view{height:100vh;overflow:hidden;display:none}
.view.active{display:block;animation:fade .35s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---------- generic page ---------- */
.page{height:100vh;overflow-y:auto}
.page-inner{max-width:900px;margin:0 auto;padding:52px 36px 90px}
.phead{margin-bottom:30px}
.phead .kick{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--coral-deep);font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:10px}
.phead h1{font-size:2.4rem;font-weight:900;letter-spacing:-.03em;line-height:1.02}
.phead .sub{color:var(--ink-soft);margin-top:8px;font-size:1.02rem;max-width:54ch}

.reveal{opacity:0;animation:rise .55s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ===================== CHAT ===================== */
#chat{display:grid;grid-template-columns:272px 1fr;height:100vh}
.side{border-right:1px solid var(--line);background:rgba(255,252,247,.7);backdrop-filter:blur(6px);display:flex;flex-direction:column}
.side .top{padding:20px 18px 14px}
.wordmark{display:flex;align-items:center}
.newbtn{margin:2px 16px 14px;padding:12px;border-radius:14px;color:#fff;background:linear-gradient(135deg,var(--coral),var(--coral-deep));font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 10px 22px -10px rgba(239,108,77,.9);transition:.16s}
.newbtn:hover{transform:translateY(-1px);box-shadow:0 14px 26px -10px rgba(239,108,77,1)}
.side .lst{flex:1;overflow-y:auto;padding:0 10px 16px}
.side .day{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);padding:16px 8px 6px;font-weight:700}
.citem{padding:11px 13px;border-radius:13px;cursor:pointer;transition:.13s;position:relative}
.citem:hover{background:var(--peach)} .citem.active{background:var(--blush)}
.citem.active::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;border-radius:99px;background:var(--coral)}
.citem .t{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.citem .s{font-size:.78rem;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}

.cmain{display:grid;grid-template-rows:auto 1fr auto;min-width:0;position:relative}
.chead{padding:16px 26px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.65);backdrop-filter:blur(8px)}
.chead .av{width:44px;height:44px;border-radius:50%;background:var(--blush);display:grid;place-items:center;box-shadow:inset 0 0 0 1px #F3DACE}
.chead .nm{font-family:var(--display);font-weight:800;font-size:1.16rem;letter-spacing:-.01em}
.chead .st{font-size:.78rem;color:var(--ok);display:flex;align-items:center;gap:6px}
.chead .st::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(92,122,63,.18)}
.chead .proj{margin-left:auto;font-size:.78rem;font-weight:600;color:var(--coral-deep);background:var(--blush);border:1px solid #F3DACE;padding:6px 14px;border-radius:99px}

.thread{overflow-y:auto;padding:32px 26px;display:flex;flex-direction:column;gap:18px}
.msg{display:flex;gap:12px;max-width:760px;animation:rise .4s ease}
.msg .av{width:34px;height:34px;border-radius:50%;flex:none;display:grid;place-items:center;margin-top:2px}
.msg.ai .av{background:var(--blush)}
.msg.me{align-self:flex-end;flex-direction:row-reverse}
.msg.me .av{background:linear-gradient(135deg,var(--mari),var(--coral));color:#fff;font-weight:700;font-size:.78rem}
.txt{padding:13px 17px;border-radius:20px;font-size:.97rem;line-height:1.55}
.msg.ai .txt{background:var(--paper);border:1px solid var(--line);border-bottom-left-radius:7px;box-shadow:var(--shadow-sm)}
.msg.me .txt{background:linear-gradient(135deg,var(--coral),var(--coral-deep));color:#fff;border-bottom-right-radius:7px;box-shadow:0 8px 20px -10px rgba(239,108,77,.8)}
.typing{display:inline-flex;align-items:center;gap:6px;background:var(--paper);border:1px solid var(--line);padding:14px 17px;border-radius:20px;border-bottom-left-radius:7px;box-shadow:var(--shadow-sm)}
.typing i{width:8px;height:8px;border-radius:50%;background:var(--coral);animation:bob 1s infinite}
.typing i:nth-child(2){animation-delay:.15s;background:var(--mari)} .typing i:nth-child(3){animation-delay:.3s}
@keyframes bob{0%,60%,100%{transform:translateY(0);opacity:.45}30%{transform:translateY(-6px);opacity:1}}

/* chat hero (accueil) */
.hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;padding:20px}
.hero .bigeyes{margin-bottom:18px;filter:drop-shadow(0 18px 30px rgba(239,108,77,.28))}
.hero h2{font-size:2.1rem;font-weight:900;letter-spacing:-.03em}
.hero p{color:var(--ink-soft);font-size:1.02rem;max-width:42ch;margin-bottom:14px}
.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:540px}
.chip{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:11px 16px;font-size:.9rem;font-weight:500;color:var(--ink-soft);cursor:pointer;transition:.15s;box-shadow:var(--shadow-sm)}
.chip:hover{border-color:var(--coral);color:var(--coral-deep);transform:translateY(-2px);box-shadow:var(--shadow-md)}

.composer{padding:16px 26px 22px;border-top:1px solid var(--line);background:rgba(255,255,255,.7);backdrop-filter:blur(8px)}
.inbar{display:flex;align-items:flex-end;gap:10px;background:#FFFCF7;border:1.5px solid var(--line);border-radius:20px;padding:14px 14px 14px 20px;transition:.16s;box-shadow:var(--shadow-sm)}
.inbar:focus-within{border-color:var(--coral);box-shadow:0 0 0 4px rgba(239,108,77,.14)}
.inbar textarea{flex:1;border:none;outline:none;resize:none;background:none;font-size:1rem;line-height:1.55;min-height:84px;max-height:280px;padding:2px 0;color:var(--ink)}
.send{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--coral),var(--coral-deep));display:grid;place-items:center;flex:none;box-shadow:0 8px 18px -8px rgba(239,108,77,.9);transition:.15s}
.send:hover{transform:scale(1.05)} .send:active{transform:scale(.96)}
.hint{text-align:center;font-size:.74rem;color:var(--ink-faint);margin-top:10px}

/* ===================== lists / cards ===================== */
.search{width:100%;padding:13px 17px;border:1.5px solid var(--line);border-radius:14px;background:rgba(255,255,255,.8);font-size:.94rem;margin-bottom:20px;transition:.16s;box-shadow:var(--shadow-sm)}
.search:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 4px rgba(239,108,77,.13)}

.dlist{display:flex;flex-direction:column;gap:11px}
.drow{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:15px;box-shadow:var(--shadow-sm);cursor:pointer;transition:.16s cubic-bezier(.2,.7,.2,1)}
.drow:hover{border-color:#F0C9BB;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.drow .ic{width:42px;height:42px;border-radius:13px;background:var(--blush);display:grid;place-items:center;flex:none}
.drow .meta{flex:1;min-width:0}
.drow .meta .t{font-weight:600}
.drow .meta .s{font-size:.84rem;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.drow .when{font-size:.8rem;color:var(--ink-faint);flex:none}
.tag{font-size:.72rem;font-weight:700;padding:4px 11px;border-radius:99px;flex:none}

/* projects */
.pgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.pcard{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:var(--shadow-sm);cursor:pointer;transition:.18s cubic-bezier(.2,.7,.2,1);position:relative;overflow:hidden}
.pcard::after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:var(--accent,#EF6C4D);opacity:.06;transition:.25s}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pcard:hover::after{transform:scale(1.4)}
.pcard .dot{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px;position:relative;z-index:1}
.pcard h3{font-size:1.18rem;font-weight:800;letter-spacing:-.01em;position:relative;z-index:1}
.pcard p{font-size:.89rem;color:var(--ink-soft);margin-top:6px;min-height:40px;position:relative;z-index:1}
.pcard .ft{display:flex;align-items:center;gap:12px;margin-top:16px;font-size:.8rem;color:var(--ink-faint);position:relative;z-index:1}
.pcard .ft b{color:var(--ink)}

/* profil */
.portrait{display:flex;align-items:center;gap:20px;background:linear-gradient(120deg,var(--paper),var(--peach));border:1px solid var(--line);border-radius:22px;padding:26px;margin-bottom:18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.portrait .big{position:absolute;right:24px;top:50%;transform:translateY(-50%);opacity:.10}
.portrait .pic{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,var(--mari),var(--coral));display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:800;font-size:1.7rem;box-shadow:0 10px 22px -8px rgba(239,108,77,.7);flex:none}
.portrait .nm{font-family:var(--display);font-weight:800;font-size:1.4rem}
.portrait .em{color:var(--ink-faint);font-size:.9rem}
.portrait .stat{margin-top:8px;font-size:.82rem;color:var(--ink-soft)}
.note{background:var(--blush);border:1px solid #F3D9CE;border-radius:16px;padding:15px 19px;font-size:.88rem;color:var(--coral-deep);margin-bottom:24px;display:flex;gap:11px;align-items:center}
.memcat{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:700;margin:24px 0 12px;display:flex;align-items:center;gap:9px}
.memcat::after{content:"";flex:1;height:1px;background:var(--line)}
.mgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:13px}
.mcard{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:17px 18px;position:relative;transition:.15s;box-shadow:var(--shadow-sm)}
.mcard:hover{border-color:#F0C9BB}
.mcard b{display:block;font-size:.72rem;color:var(--coral-deep);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-weight:700}
.mcard p{font-size:.92rem;color:var(--ink)}
.mcard .x{position:absolute;top:12px;right:14px;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;color:var(--ink-faint);font-size:1rem;opacity:0;transition:.15s;line-height:1}
.mcard:hover .x{opacity:1}
.mcard .x:hover{background:var(--blush);color:var(--coral)}

/* downloads */
.dl{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:17px;box-shadow:var(--shadow-sm);margin-bottom:11px;transition:.15s}
.dl:hover{box-shadow:var(--shadow-md)}
.dl .ft{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:.68rem;color:#fff;flex:none;letter-spacing:.02em}
.dl .meta{flex:1;min-width:0}
.dl .meta .t{font-weight:600}
.dl .meta .s{font-size:.82rem;color:var(--ink-faint);margin-top:1px}
.dl .ring{flex:none;display:grid;place-items:center;position:relative;width:42px;height:42px}
.dl .ring .lbl{font-size:.62rem;font-weight:800;position:absolute;color:var(--ink-soft)}
.dl .btn-dl{flex:none;background:var(--coral);color:#fff;font-weight:600;font-size:.85rem;padding:10px 17px;border-radius:11px;display:flex;align-items:center;gap:7px;transition:.15s}
.dl .btn-dl:hover{background:var(--coral-deep);transform:translateY(-1px)}
.dl.expired{opacity:.58}
.dl.expired .btn-dl{background:var(--sand);color:var(--ink-faint);cursor:not-allowed;transform:none}
.dl .expnote{font-size:.72rem;color:var(--ink-faint);text-align:center;margin-top:2px}

.empty{text-align:center;color:var(--ink-faint);padding:54px 0;font-size:.92rem;display:flex;flex-direction:column;align-items:center;gap:14px}
.empty .eyes{opacity:.4}
/* settings */
.scard{background:var(--paper);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);margin-bottom:18px;overflow:hidden}
.scard .sh{padding:18px 22px 4px;font-family:var(--display);font-weight:800;font-size:1.12rem;letter-spacing:-.01em}
.scard .ss{padding:0 22px 14px;font-size:.83rem;color:var(--ink-faint)}
.srow{display:flex;align-items:center;gap:16px;padding:15px 22px;border-top:1px solid var(--line-soft)}
.srow .lab{flex:1}.srow .lab .t{font-weight:600;font-size:.95rem}.srow .lab .d{font-size:.82rem;color:var(--ink-faint);margin-top:2px}
.srow .val{font-size:.9rem;color:var(--ink-soft)}
.tg{width:48px;height:27px;border-radius:99px;background:#DDD2C0;position:relative;transition:.2s;flex:none;cursor:pointer}
.tg::after{content:"";position:absolute;width:21px;height:21px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.2s;box-shadow:var(--shadow-sm)}
.tg.on{background:var(--coral)}.tg.on::after{left:24px}
.sslider{-webkit-appearance:none;appearance:none;width:170px;height:6px;border-radius:99px;background:var(--blush);outline:none}
.sslider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--coral);cursor:pointer;box-shadow:var(--shadow-sm)}
.ssel{font-family:inherit;font-size:.9rem;padding:9px 13px;border:1px solid var(--line);border-radius:10px;background:#FFFCF7;color:var(--ink)}
.ssel:focus{outline:none;border-color:var(--coral)}
.seg{display:flex;gap:4px;background:var(--blush);padding:4px;border-radius:11px}
.seg button{padding:7px 15px;border-radius:8px;font-size:.85rem;font-weight:600;color:var(--coral-deep)}
.seg button.on{background:var(--paper);box-shadow:var(--shadow-sm);color:var(--ink)}
.sbtn{font-weight:600;font-size:.88rem;border-radius:11px;padding:10px 17px;display:inline-flex;align-items:center;gap:8px}
.sbtn.primary{background:var(--coral);color:#fff}.sbtn.primary:hover{background:var(--coral-deep)}
.sbtn.line{border:1px solid var(--line);color:var(--ink)}.sbtn.line:hover{background:var(--peach)}
.sbtn.danger{border:1px solid #E7C9C0;color:var(--warn)}.sbtn.danger:hover{background:var(--blush)}

/* project detail */
.backbtn{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:.88rem;color:var(--ink-soft);margin-bottom:18px;padding:8px 14px;border-radius:11px;background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.backbtn:hover{color:var(--coral-deep);border-color:#F0C9BB}
.pdhead{display:flex;align-items:center;gap:18px;border-radius:22px;padding:26px;margin-bottom:22px;box-shadow:var(--shadow-sm);border:1px solid var(--line);position:relative;overflow:hidden}
.pdhead .pdico{width:58px;height:58px;border-radius:17px;display:grid;place-items:center;flex:none}
.pdhead h1{font-size:1.9rem;font-weight:900;letter-spacing:-.02em}
.pdhead p{color:var(--ink-soft);font-size:.95rem;margin-top:3px}
.pdhead .stats{display:flex;gap:22px;margin-top:12px;font-size:.84rem;color:var(--ink-faint)}
.pdhead .stats b{color:var(--ink);font-family:var(--display);font-size:1.05rem}
.pdhead .go{margin-left:auto}

@media(max-width:860px){.pgrid,.mgrid{grid-template-columns:1fr}#chat{grid-template-columns:210px 1fr}}
@media(max-width:600px){.side{display:none}#chat{grid-template-columns:1fr}}
