*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --pink:#FF6B9D;--orange:#FF9A3C;--yellow:#FFD200;
  --teal:#4ECDC4;--td:#44A08D;
  --purple:#8B5CF6;--pl:#A18CD1;
  --blue:#2F80ED;--bl:#56CCF2;
  --green:#11998e;--gl:#38ef7d;
  --gold:#f7971e;--gol:#ffd200;
  --night:#1a1a2e;--rose:#eb3349;
  --bg:#FFF9F5;--bg2:#F5F0FA;--card:#fff;
  --text:#2D2D3A;--t2:#666;--t3:#AAA;
  --bdr:#EDE8F8;
  --gb:linear-gradient(135deg,#FF6B9D,#FF9A3C,#FFD200);
  --gt:linear-gradient(135deg,#4ECDC4,#44A08D);
  --gp:linear-gradient(135deg,#8B5CF6,#A18CD1);
  --gbl:linear-gradient(135deg,#56CCF2,#2F80ED);
  --gg:linear-gradient(135deg,#11998e,#38ef7d);
  --go:linear-gradient(135deg,#f7971e,#ffd200);
  --gn:linear-gradient(135deg,#1a1a2e,#4a4a8e,#8B5CF6);
  --gw:linear-gradient(135deg,#eb3349,#f45c43);
  --r12:12px;--r18:18px;--r24:24px;
  --s1:0 2px 12px rgba(0,0,0,.07);
  --s2:0 6px 24px rgba(0,0,0,.10);
  --s3:0 12px 40px rgba(0,0,0,.14);
  --tr:.18s cubic-bezier(.4,0,.2,1);
}
html,body{height:100%;font-family:'Nunito',sans-serif;background:var(--bg2);color:var(--text);overflow-x:hidden}
button{font-family:'Nunito',sans-serif;cursor:pointer}
input,textarea,select{font-family:'Nunito',sans-serif}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:4px}
.app-shell{display:flex;flex-direction:column;min-height:100vh}
/* APPBAR */
.appbar{display:flex;align-items:center;gap:14px;padding:11px 20px;background:var(--card);border-bottom:1.5px solid var(--bdr);position:sticky;top:0;z-index:200;box-shadow:var(--s1)}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand-mark{width:36px;height:36px;border-radius:11px;background:var(--gb);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:14px;font-weight:900;color:#fff;box-shadow:0 4px 12px rgba(255,107,157,.35)}
.brand-title{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;color:var(--text);line-height:1.1}
.brand-sub{font-size:10px;color:var(--t3);font-weight:600;letter-spacing:.4px}
.mode-bar{display:flex;background:var(--bg2);border-radius:18px;padding:3px;border:1.5px solid var(--bdr);gap:2px;margin-left:8px}
.mode-btn{padding:7px 18px;border:none;border-radius:14px;font-size:13px;font-weight:700;color:var(--t2);background:transparent;transition:var(--tr);white-space:nowrap}
.mode-btn.active{background:var(--gp);color:#fff;box-shadow:0 4px 14px rgba(139,92,246,.3)}
.app-right{display:flex;align-items:center;gap:10px;margin-left:auto}
.notif-btn{position:relative;width:38px;height:38px;border-radius:50%;background:var(--bg2);border:1.5px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:17px;transition:var(--tr)}
.notif-dot{width:9px;height:9px;background:var(--pink);border-radius:50%;position:absolute;top:3px;right:3px;border:2px solid #fff}
.uav{width:38px;height:38px;border-radius:50%;background:var(--gb);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:#fff;box-shadow:0 4px 10px rgba(255,107,157,.25);flex-shrink:0}
/* HAMBURGER */
.hbtn{display:flex;width:42px;height:42px;border-radius:13px;background:var(--bg2);border:1.5px solid var(--bdr);align-items:center;justify-content:center;flex-direction:column;gap:5px;padding:10px;transition:var(--tr);flex-shrink:0}
.hbtn:hover{background:var(--bdr)}
.hbtn.open{background:var(--gp);border-color:transparent}
.hl{width:100%;height:2px;border-radius:2px;background:var(--t2);transition:var(--tr);transform-origin:center}
.hbtn.open .hl{background:#fff}
.hbtn.open .hl:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hbtn.open .hl:nth-child(2){opacity:0;transform:scaleX(0)}
.hbtn.open .hl:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* SIDEBAR */
.sb-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:250;backdrop-filter:blur(2px)}
.sb-ov.open{display:block}
.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:300;width:272px;background:var(--card);border-right:1.5px solid var(--bdr);padding:70px 10px 20px;display:flex;flex-direction:column;gap:3px;overflow-y:auto;transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:var(--s3)}
.sidebar.open{transform:translateX(0)}
.sb-sec{font-size:10px;font-weight:800;color:var(--t3);letter-spacing:1px;text-transform:uppercase;padding:12px 12px 5px;margin-top:6px}
.ni{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:11px;border:none;background:transparent;width:100%;text-align:left;transition:var(--tr);color:var(--t2);font-size:13px;font-weight:600;position:relative}
.ni:hover{background:var(--bg2);color:var(--text)}
.ni.active{background:var(--bg2);color:var(--purple);font-weight:700}
.ni.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--gp);border-radius:0 3px 3px 0}
.nii{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;background:var(--bg2);transition:var(--tr)}
.ni.active .nii{background:var(--gp);box-shadow:0 4px 10px rgba(139,92,246,.3)}
.nb{margin-left:auto;background:var(--pink);color:#fff;font-size:10px;font-weight:800;padding:2px 7px;border-radius:10px}
/* CONTENT */
.main-wrap{display:flex;flex:1;overflow:hidden}
.content-area{flex:1;overflow-y:auto;padding:0}
.sc{display:none;animation:fi .2s ease}
.sc.active{display:block}
@keyframes fi{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
/* PAGE HERO */
.ph{padding:28px 28px 0;background:var(--card);border-bottom:1.5px solid var(--bdr)}
.ph-in{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:14px;padding-bottom:22px}
.ph h1{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:var(--text);line-height:1.1}
.ph .hs{font-size:13px;color:var(--t2);margin-top:4px;font-weight:600}
.hstats{display:flex;gap:10px;flex-wrap:wrap}
.hst{background:var(--bg2);border-radius:var(--r12);padding:9px 16px;text-align:center;border:1.5px solid var(--bdr);min-width:76px}
.hsn{font-family:'Syne',sans-serif;font-size:20px;font-weight:800}
.hsl{font-size:11px;color:var(--t3);font-weight:700;margin-top:1px}
.gb5{height:5px;background:var(--gb)}
.pb{padding:24px 28px}
/* GRID */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.ga{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
/* FEATURE CARD */
.fc{border-radius:var(--r24);padding:20px;display:flex;flex-direction:column;gap:10px;cursor:pointer;transition:var(--tr);border:none;text-align:left;box-shadow:var(--s1);position:relative;overflow:hidden}
.fc::after{content:'';position:absolute;bottom:-25px;right:-25px;width:90px;height:90px;border-radius:50%;background:rgba(255,255,255,.12);pointer-events:none}
.fc:hover{transform:translateY(-4px);box-shadow:var(--s3)}
.fc-ico{width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-size:22px;border:1.5px solid rgba(255,255,255,.3)}
.fc-t{font-family:'Syne',sans-serif;font-size:14px;font-weight:800;color:#fff;line-height:1.2}
.fc-s{font-size:11px;color:rgba(255,255,255,.8);font-weight:600}
.c-pink{background:linear-gradient(135deg,#FF6B9D,#FF9A3C)}
.c-teal{background:linear-gradient(135deg,#4ECDC4,#44A08D)}
.c-purple{background:linear-gradient(135deg,#8B5CF6,#A18CD1)}
.c-blue{background:linear-gradient(135deg,#56CCF2,#2F80ED)}
.c-green{background:linear-gradient(135deg,#11998e,#38ef7d)}
.c-gold{background:linear-gradient(135deg,#f7971e,#ffd200)}
.c-night{background:linear-gradient(135deg,#1a1a2e,#4a4a8e)}
.c-warm{background:linear-gradient(135deg,#eb3349,#f45c43)}
.c-indigo{background:linear-gradient(135deg,#4776E6,#8E54E9)}
.c-mint{background:linear-gradient(135deg,#00b09b,#96c93d)}
.c-plum{background:linear-gradient(135deg,#6a0572,#ab83a1)}
.c-sky{background:linear-gradient(135deg,#0575E6,#021B79)}
.c-rose{background:linear-gradient(135deg,#f953c6,#b91d73)}
.c-amber{background:linear-gradient(135deg,#f46b45,#eea849)}
.c-sage{background:linear-gradient(135deg,#56ab2f,#a8e063)}
.c-ocean{background:linear-gradient(135deg,#2E3192,#1BFFFF)}
/* WHITE CARD */
.wc{background:var(--card);border-radius:var(--r18);padding:18px;border:1.5px solid var(--bdr);box-shadow:var(--s1)}
.wct{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px}
/* BADGE */
.bdg{font-size:11px;font-weight:800;padding:3px 11px;border-radius:20px;white-space:nowrap}
.ba{background:#E8FBF4;color:#2D9F6B}
.bpo{background:#FFF0E8;color:#E07C3A}
.bn{background:#E8F0FF;color:#4A7CE8}
.bv{background:#EEF2FF;color:#667eea}
.bpr{background:#F0EBF8;color:var(--purple)}
.bw{background:#FEF3C7;color:#92400E}
.bdr2{background:#FEF0F0;color:#E53E3E}
/* BTN SMALL */
.bs{padding:6px 13px;border-radius:10px;font-size:12px;font-weight:700;border:none;transition:var(--tr);white-space:nowrap}
.bs:hover{filter:brightness(1.05)}
.bt{background:var(--gt);color:#fff}
.bp2{background:var(--gp);color:#fff}
.bb{background:var(--gbl);color:#fff}
.bg2{background:var(--gg);color:#fff}
.bo2{background:var(--go);color:#fff}
.bgh{background:var(--bg2);color:var(--t2);border:1.5px solid var(--bdr)}
/* CONFIRM BTN */
.cbtn{display:block;width:100%;padding:14px;border-radius:var(--r18);border:none;font-family:'Syne',sans-serif;font-size:15px;font-weight:800;color:#fff;cursor:pointer;text-align:center;transition:var(--tr);box-shadow:var(--s2);margin-top:14px}
.cbtn:hover{transform:translateY(-2px);box-shadow:var(--s3)}
/* METRICS */
.mg2{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.mg3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.mg4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.met{background:var(--card);border-radius:var(--r18);padding:16px;border:1.5px solid var(--bdr);text-align:center;box-shadow:var(--s1)}
.mn{font-family:'Syne',sans-serif;font-size:28px;font-weight:900;line-height:1}
.ml2{font-size:11px;color:var(--t3);font-weight:700;margin-top:5px}
.mtu{font-size:11px;color:#2D9F6B;margin-top:3px;font-weight:700}
.mtd{font-size:11px;color:#E53E3E;margin-top:3px;font-weight:700}
/* CHIP */
.chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:16px}
.chip{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;border:1.5px solid var(--bdr);color:var(--t2);background:var(--card);transition:var(--tr)}
.chip:hover{border-color:var(--purple);color:var(--purple)}
.chip.on{background:var(--gp);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(139,92,246,.25)}
/* INPUT */
.fld{margin-bottom:12px}
.fld label{display:block;font-size:13px;font-weight:700;color:var(--t2);margin-bottom:4px}
.fld input,.fld textarea,.fld select{width:100%;padding:10px 14px;border-radius:11px;border:1.5px solid var(--bdr);background:var(--bg2);font-size:13px;color:var(--text);outline:none;transition:var(--tr)}
.fld input:focus,.fld textarea:focus{border-color:var(--purple);background:var(--card)}
.fld textarea{min-height:90px;resize:vertical}
/* PROGRESS BAR */
.sbar{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.slbl{font-size:12px;font-weight:700;color:var(--t2);min-width:100px}
.strk{flex:1;height:9px;background:var(--bg2);border-radius:5px;overflow:hidden;border:1px solid var(--bdr)}
.sfil{height:100%;border-radius:5px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.sval{font-size:12px;font-weight:700;color:var(--purple);min-width:34px;text-align:right}
/* PATIENT ITEM */
.pi{display:flex;align-items:flex-start;gap:13px;padding:13px;background:var(--card);border-radius:var(--r18);border:1.5px solid var(--bdr);margin-bottom:10px;transition:var(--tr);cursor:pointer}
.pi:hover{border-color:var(--purple);box-shadow:var(--s1)}
.pav{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:#fff;flex-shrink:0}
/* DREAM */
.drm{background:linear-gradient(135deg,#0f0f1e,#1a1a3e);border-radius:var(--r18);padding:20px;margin-bottom:12px}
.drm-d{font-size:10px;font-weight:700;color:rgba(255,255,255,.4);margin-bottom:7px;text-transform:uppercase;letter-spacing:.5px}
.drm-t{font-size:13px;color:rgba(255,255,255,.88);line-height:1.65;margin-bottom:12px}
.arch-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:10px}
.arch{display:inline-block;padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700}
.a-pu{background:rgba(139,92,246,.3);color:#C4B5FD}
.a-go{background:rgba(251,191,36,.2);color:#FDE68A}
.a-pk{background:rgba(236,72,153,.25);color:#F9A8D4}
.a-bl{background:rgba(56,200,253,.2);color:#7DD3FC}
.drm-ai{background:rgba(139,92,246,.15);border-radius:10px;padding:10px;border:1px solid rgba(139,92,246,.2)}
.drm-ai-t{font-size:11px;color:#A78BFA;font-weight:700;margin-bottom:4px}
.drm-ai-b{font-size:12px;color:rgba(255,255,255,.6);line-height:1.55}
/* TIMELINE */
.tl{padding:0 0 0 26px;position:relative}
.tl::before{content:'';position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--bdr)}
.tl-it{position:relative;padding-bottom:18px}
.tl-dot{width:16px;height:16px;border-radius:50%;position:absolute;left:-30px;top:3px;border:3px solid var(--card);box-shadow:0 0 0 2px currentColor}
.tl-dt{font-size:10px;font-weight:800;color:var(--t3);margin-bottom:3px;text-transform:uppercase;letter-spacing:.5px}
.tl-ti{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tl-bd{font-size:13px;color:var(--t2);line-height:1.6}
/* CALENDAR */
.cal{background:var(--card);border-radius:var(--r18);padding:18px;border:1.5px solid var(--bdr)}
.cal-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-nav{width:30px;height:30px;border-radius:50%;background:var(--bg2);border:1.5px solid var(--bdr);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;font-weight:700;color:var(--t2);transition:var(--tr)}
.cal-g{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;text-align:center}
.cal-dh{font-size:10px;font-weight:800;color:var(--t3);padding:5px 0;text-transform:uppercase}
.cal-d{font-size:12px;font-weight:600;padding:6px 3px;border-radius:9px;cursor:pointer;color:var(--t2);transition:var(--tr)}
.cal-d:hover{background:var(--bg2)}
.cal-d.today{border:2px solid var(--green);color:var(--green);font-weight:800}
.cal-d.has{background:var(--gp);color:#fff;font-weight:800}
.cal-d.blk{background:#FFE8EF;color:var(--pink);text-decoration:line-through}
.cal-d.mt{pointer-events:none;opacity:0}
/* SLOTS */
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(74px,1fr));gap:7px;margin:12px 0}
.slot{padding:9px 5px;text-align:center;border-radius:11px;font-size:12px;font-weight:700;cursor:pointer;border:1.5px solid var(--bdr);color:var(--t2);background:var(--card);transition:var(--tr)}
.slot:hover{border-color:var(--green);color:var(--green)}
.slot.on{background:var(--gg);color:#fff;border-color:transparent}
.slot.tk{opacity:.4;pointer-events:none;text-decoration:line-through}
/* RDV */
.rdvi{display:flex;align-items:center;gap:13px;background:var(--card);border-radius:var(--r18);padding:13px 15px;margin-bottom:9px;border:1.5px solid var(--bdr);cursor:pointer;transition:var(--tr)}
.rdvi:hover{border-color:var(--purple);box-shadow:var(--s1)}
.rdvt{background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(161,140,209,.15));border-radius:11px;padding:9px 11px;text-align:center;min-width:54px;flex-shrink:0}
.rdvh{font-size:16px;font-weight:800;color:var(--purple);line-height:1}
.rdvd{font-size:10px;color:var(--t3);font-weight:700;margin-top:2px}
/* CHAT */
.chat-c{display:flex;flex-direction:column;height:calc(100vh - 190px);min-height:380px}
.chat-msgs{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:3px;background:var(--bg2)}
.cbw{display:flex;flex-direction:column;margin-bottom:5px}
.cbw.out{align-items:flex-end}
.cb{max-width:68%;padding:11px 15px;border-radius:17px;font-size:13px;line-height:1.6}
.cb.in{background:var(--card);border:1.5px solid var(--bdr);border-bottom-left-radius:4px;color:var(--text)}
.cb.out{background:var(--go);color:#fff;border-bottom-right-radius:4px}
.cm{font-size:10px;color:var(--t3);padding:0 4px;margin-top:2px}
.chat-inp{display:flex;gap:9px;align-items:center;padding:13px 18px;background:var(--card);border-top:1.5px solid var(--bdr);flex-shrink:0}
.cinput{flex:1;border:1.5px solid var(--bdr);border-radius:22px;padding:10px 16px;font-size:13px;outline:none;color:var(--text);background:var(--bg2);transition:var(--tr)}
.cinput:focus{border-color:var(--purple);background:var(--card)}
.sbtn{width:42px;height:42px;border-radius:50%;border:none;background:var(--go);display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff;box-shadow:0 4px 12px rgba(247,151,30,.35);transition:var(--tr)}
/* AUDIO */
.rec-bar{display:flex;align-items:center;gap:10px;background:var(--bg2);border-radius:14px;padding:12px 16px;border:1.5px solid var(--bdr);margin-bottom:12px}
.rec-btn{width:44px;height:44px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;transition:var(--tr)}
.rec-wave{flex:1;height:36px;display:flex;align-items:center;gap:2px}
.rw{width:3px;border-radius:2px;background:var(--pl);animation:wave 1s ease-in-out infinite}
.rw:nth-child(1){height:8px;animation-delay:0s}.rw:nth-child(2){height:20px;animation-delay:.1s}.rw:nth-child(3){height:14px;animation-delay:.2s}.rw:nth-child(4){height:28px;animation-delay:.3s}.rw:nth-child(5){height:18px;animation-delay:.4s}.rw:nth-child(6){height:10px;animation-delay:.5s}.rw:nth-child(7){height:24px;animation-delay:.6s}.rw:nth-child(8){height:16px;animation-delay:.7s}.rw:nth-child(9){height:8px;animation-delay:.8s}.rw:nth-child(10){height:20px;animation-delay:.9s}
@keyframes wave{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.8)}}
.rec-time{font-size:13px;font-weight:800;color:var(--purple);min-width:40px}
/* PHOTO DROP */
.pdrop{border:2.5px dashed var(--bdr);border-radius:var(--r18);padding:28px;text-align:center;cursor:pointer;transition:var(--tr);background:var(--bg2)}
.pdrop:hover{border-color:var(--purple);background:var(--card)}
.pdrop .pdi{font-size:40px;margin-bottom:10px}
.pdrop .pdt{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}
.pdrop .pds{font-size:12px;color:var(--t3);font-weight:600}
/* GRATITUDE */
.grat{background:linear-gradient(135deg,#fff9f0,#fff0f5);border-radius:var(--r18);padding:18px;border:1.5px solid #FFD4B2;margin-bottom:10px}
.grat-d{font-size:10px;font-weight:800;color:var(--orange);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.grat ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.grat li{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--text);line-height:1.5}
.grat li::before{content:'✦';color:var(--orange);font-size:14px;flex-shrink:0;margin-top:1px}
/* BACH FLOWERS */
.bach{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-radius:var(--r18);padding:16px;border:1.5px solid #A7F3D0;margin-bottom:10px}
.bach-n{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;color:#065F46;margin-bottom:4px}
.bach-e{font-size:12px;font-weight:700;color:#10B981;margin-bottom:6px}
.bach-desc{font-size:12px;color:#374151;line-height:1.55}
.bach-sc{display:flex;align-items:center;gap:8px;margin-top:8px}
.bach-tr{flex:1;height:7px;background:rgba(0,0,0,.06);border-radius:4px;overflow:hidden}
.bach-fl{height:100%;border-radius:4px;background:linear-gradient(90deg,#10B981,#34D399)}
/* NOTE CARD */
.nc{background:var(--card);border-radius:var(--r18);padding:15px;border:1.5px solid var(--bdr);margin-bottom:9px;transition:var(--tr)}
.nc:hover{border-color:var(--purple);box-shadow:var(--s1)}
.nc-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}
.nc-t{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--t2)}
.nc-b{font-size:13px;color:var(--text);line-height:1.6}
/* AI SUGGESTION */
.aisu{background:linear-gradient(135deg,#FFF8E8,#FFF0E8);border-radius:var(--r18);padding:15px;border:1.5px solid #FFD4A2;margin-bottom:14px}
.aisu-t{font-size:11px;font-weight:800;color:var(--orange);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.aisu-b{font-size:13px;color:var(--t2);line-height:1.6;margin-bottom:9px}
.aisu-a{display:flex;gap:7px;flex-wrap:wrap}
/* TA */
.ta-box{border-radius:12px;padding:12px;text-align:center;cursor:pointer;transition:var(--tr);border:2px solid transparent}
.ta-box:hover{transform:translateY(-2px);box-shadow:var(--s2)}
.ta-P{background:linear-gradient(135deg,#E0E7FF,#C7D2FE)}
.ta-A{background:linear-gradient(135deg,#D1FAE5,#A7F3D0)}
.ta-E{background:linear-gradient(135deg,#FEF3C7,#FDE68A)}
/* MF ARCHETYPE */
.mf-row{display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid var(--bdr)}
.mf-row:last-child{border-bottom:none}
.mf-nm{font-size:13px;font-weight:700;color:var(--text);min-width:120px}
.mf-bw{flex:1;height:7px;background:var(--bg2);border-radius:4px;overflow:hidden}
.mf-bf{height:100%;border-radius:4px}
.mf-pct{font-size:11px;font-weight:700;min-width:30px;text-align:right}
.inf-tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;margin-left:6px}
/* VD CARD */
.vd{border-radius:var(--r18);padding:16px;margin-bottom:10px;border:1.5px solid var(--bdr);cursor:pointer;transition:var(--tr)}
.vd:hover{box-shadow:var(--s2);transform:translateY(-2px)}
.vd-h{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.vd-ico{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.vd-nm{font-family:'Syne',sans-serif;font-size:14px;font-weight:800}
.vd-tp{font-size:11px;font-weight:700;margin-top:1px}
.vd-desc{font-size:12px;color:var(--t2);line-height:1.55;margin-bottom:8px}
/* REVENUE */
.rev-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--bdr)}
.rev-row:last-child{border-bottom:none}
/* SECTION HEADER */
.shdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:7px}
.shdr h2{font-family:'Syne',sans-serif;font-size:17px;font-weight:800;color:var(--text)}
/* BOTTOM NAV */
.bnav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1.5px solid var(--bdr);padding:7px 4px 18px;z-index:300;box-shadow:0 -4px 20px rgba(0,0,0,.08)}
.bnav-r{display:flex;justify-content:space-around}
.bni{display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 10px;border-radius:13px;cursor:pointer;transition:var(--tr);border:none;background:transparent;flex:1}
.bni-ico{font-size:21px}
.bni-lbl{font-size:10px;font-weight:700;color:var(--t3)}
.bni.active .bni-lbl{color:var(--purple)}
/* RESSENTI */
.rg-items{display:flex;gap:7px;flex-wrap:wrap}
.ri{padding:5px 13px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;transition:var(--tr);border:1.5px solid transparent}
.ri:hover{opacity:.85}
/* NEUROVEGETATIF */
.nv-zone{border-radius:var(--r18);padding:18px;margin-bottom:14px;position:relative;overflow:hidden}
.nv-rouge{background:linear-gradient(135deg,#FFF0F0,#FFE0E0);border:2px solid #FECACA}
.nv-bleu{background:linear-gradient(135deg,#EFF6FF,#DBEAFE);border:2px solid #BFDBFE}
.nv-blanc{background:linear-gradient(135deg,#F9FAFB,#F3F4F6);border:2px solid #E5E7EB}
.nv-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:800;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.nv-sub{font-size:12px;font-weight:600;margin-bottom:12px;opacity:.8}
.nv-tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:10px}
.nv-tag{padding:5px 13px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;transition:var(--tr);border:none}
.nv-tag:hover{transform:translateY(-2px);box-shadow:var(--s1)}
.nv-tag.sel{box-shadow:0 0 0 2px rgba(0,0,0,.15);transform:scale(1.05)}
.nv-r .nv-tag{background:rgba(239,68,68,.15);color:#991B1B}
.nv-r .nv-tag.sel{background:#EF4444;color:#fff}
.nv-b .nv-tag{background:rgba(59,130,246,.15);color:#1E40AF}
.nv-b .nv-tag.sel{background:#3B82F6;color:#fff}
.nv-w .nv-tag{background:rgba(107,114,128,.12);color:#374151}
.nv-w .nv-tag.sel{background:#6B7280;color:#fff}
.nv-schema{position:relative;height:280px;background:linear-gradient(180deg,#fff,var(--bg2));border-radius:var(--r18);border:1.5px solid var(--bdr);overflow:hidden;margin-bottom:14px}
/* PAIEMENT CARD */
.plan-card{border-radius:var(--r18);padding:20px;border:2px solid var(--bdr);position:relative;cursor:pointer;transition:var(--tr)}
.plan-card:hover{border-color:var(--purple);box-shadow:var(--s2)}
.plan-card.selected{border-color:var(--purple);background:linear-gradient(135deg,#F5F3FF,#EDE9FE)}
.plan-card.popular::before{content:'Recommandé';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gp);color:#fff;font-size:11px;font-weight:800;padding:3px 14px;border-radius:20px;white-space:nowrap}
.plan-price{font-family:'Syne',sans-serif;font-size:36px;font-weight:900;color:var(--purple);line-height:1}
.plan-period{font-size:13px;color:var(--t2);font-weight:600}
.plan-features{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:6px}
.plan-features li{font-size:12px;font-weight:600;color:var(--t2);display:flex;align-items:center;gap:7px}
.plan-features li::before{content:'✓';color:var(--green);font-weight:900;font-size:13px}
.plan-features li.no::before{content:'✗';color:var(--t3)}
.plan-features li.no{color:var(--t3)}
/* COMPTA */
.compta-table{width:100%;border-collapse:collapse;font-size:13px}
.compta-table th{background:var(--bg2);padding:9px 12px;text-align:left;font-size:11px;font-weight:800;color:var(--t2);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--bdr)}
.compta-table td{padding:10px 12px;border-bottom:1px solid var(--bdr);color:var(--text);vertical-align:middle}
.compta-table tr:hover td{background:var(--bg2)}
.compta-table .amount{font-family:'Syne',sans-serif;font-weight:700;text-align:right}
.compta-table .positive{color:var(--green)}
.compta-table .negative{color:var(--rose)}
.compta-table .neutral{color:var(--t2)}
.type-pill{padding:3px 10px;border-radius:20px;font-size:10px;font-weight:800;white-space:nowrap}
/* PAIEMENT METHOD */
.pm-card{background:var(--card);border-radius:var(--r18);padding:16px;border:1.5px solid var(--bdr);display:flex;align-items:center;gap:14px;cursor:pointer;transition:var(--tr)}
.pm-card:hover{border-color:var(--purple);box-shadow:var(--s1)}
.pm-card.active{border-color:var(--purple);background:linear-gradient(135deg,#F5F3FF,#EDE9FE)}
.pm-ico{width:48px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;font-weight:800}
/* INVOICE */
.inv-row{display:flex;align-items:center;gap:12px;background:var(--card);border-radius:var(--r18);padding:13px 15px;margin-bottom:8px;border:1.5px solid var(--bdr);transition:var(--tr)}
.inv-row:hover{border-color:var(--purple);box-shadow:var(--s1)}
/* RESPONSIVE */
@media(max-width:1024px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .mg4{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:1fr 1fr}
  .pb{padding:18px}
  .ph{padding:22px 22px 0}
}
@media(max-width:767px){
  .mode-bar{display:none}
  .bnav{display:block}
  .content-area{padding-bottom:86px}
  .g2,.g3,.g4{grid-template-columns:1fr 1fr}
  .mg3,.mg4{grid-template-columns:repeat(2,1fr)}
  .pb{padding:14px}
  .ph{padding:16px 14px 0}
  .ph h1{font-size:21px}
  .chat-c{height:calc(100vh - 150px)}
  .appbar{padding:9px 13px}
}
@media(max-width:480px){
  .g2,.g3,.g4{grid-template-columns:1fr}
}

/* Django: one section partial per page (not SPA) — show the single .sc block */
.content-area-mc .sc{display:block!important;}

/* Portail — retour accueil + formulaires rêve + fiche analyse */
.mc-back-bar{padding:12px 28px 0;background:var(--card);border-bottom:1px solid var(--bdr)}
.mc-back-link{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--purple);text-decoration:none}
.mc-back-link:hover{text-decoration:underline}
.mc-form-stack .mc-field{margin-bottom:14px}
.mc-form-stack label{display:block;font-size:12px;font-weight:700;color:var(--t2);margin-bottom:5px}
.mc-input,.mc-textarea{width:100%;padding:10px 12px;border:1.5px solid var(--bdr);border-radius:10px;font-size:14px;background:var(--card)}
.mc-textarea{min-height:180px;resize:vertical}
.mc-form-errors{color:#b91c1c;font-size:13px;margin-bottom:10px}
.mc-field-err{color:#b91c1c;font-size:12px;margin-top:4px}
.dream-detail-grid{display:flex;flex-direction:column;gap:14px;max-width:900px}
.dream-panel-c1{border-left:4px solid var(--purple)}
.dream-panel-c2{border-left:4px solid var(--teal)}
.dream-panel-c4{border-left:4px solid var(--orange)}
.dream-status-pill{display:inline-block;font-size:11px;font-weight:800;text-transform:uppercase;padding:3px 8px;border-radius:8px;background:var(--bg2);color:var(--t2);vertical-align:middle;margin-left:8px}
.dream-expert-summary{font-size:14px;line-height:1.45;margin:8px 0}
.dream-elements{margin:10px 0 0 18px;font-size:13px;line-height:1.4}
.dream-elements li{margin-bottom:6px}
.dream-tag{display:inline-block;margin-left:6px;font-size:11px;color:var(--purple);font-weight:700}
.dream-json-snippet{font-size:11px;background:var(--bg2);padding:10px;border-radius:8px;overflow:auto;max-height:220px;border:1px solid var(--bdr);white-space:pre-wrap;word-break:break-word}
.dream-session-log{font-size:13px;line-height:1.45;margin:8px 0 0 18px}
.dream-session-log li{margin-bottom:8px}
.dream-final-narrative{font-size:14px;line-height:1.5;margin-top:10px}
.drm-link{border:1.5px solid var(--bdr);border-radius:var(--r12);padding:12px;margin-bottom:10px;transition:var(--tr)}
.drm-link:hover{border-color:var(--purple);box-shadow:var(--s1)}
.drm-more{display:block;font-size:12px;font-weight:700;color:var(--purple);margin-top:8px}
