@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap";.sidebar{width:280px;min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}.sidebar-logo{padding:28px 24px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px}.logo-mark{width:44px;height:44px;background:var(--gold);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#000;flex-shrink:0}.logo-text{font-size:22px;font-weight:800;letter-spacing:-.5px;color:var(--text)}.logo-sub{font-size:11px;color:var(--text-dim);font-weight:400;letter-spacing:.5px;margin-top:2px}.sidebar-nav{flex:1;padding:20px 14px;display:flex;flex-direction:column;gap:4px}.nav-section{font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--text-dim);padding:12px 14px 8px;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);font-size:14px;font-weight:600;color:var(--text-mid);text-decoration:none;position:relative}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:#e8a8381f;color:var(--gold)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--gold);border-radius:0 4px 4px 0}.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;font-family:var(--mono)}.sidebar-user{margin:0 16px 20px;padding:16px;background:var(--surface2);border-radius:var(--radius-sm);display:flex;align-items:center;gap:12px;border:1px solid var(--border)}.user-info{flex:1;min-width:0}.user-name{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;color:var(--text-dim);margin-top:2px}.logout-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:8px;border-radius:8px;transition:var(--transition);display:flex;align-items:center;justify-content:center}.logout-btn:hover{color:var(--red);background:#ff6b6b1a}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:1000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px;animation:fadeIn .2s ease}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideUp .3s ease}.modal-sm{max-width:400px}.modal-md{max-width:520px}.modal-lg{max-width:720px}.modal-xl{max-width:960px}.modal-full{max-width:calc(100vw - 40px)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 0;gap:16px}.modal-title{font-size:20px;font-weight:700;letter-spacing:-.3px;color:var(--text);margin:0}.modal-close{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:8px;border-radius:8px;transition:var(--transition);display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--text);background:var(--surface2)}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:0 24px 24px;border-top:1px solid var(--border);margin-top:auto}.modal-footer .btn{min-width:100px}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.modal-backdrop{padding:0;align-items:flex-end}.modal{border-radius:var(--radius) var(--radius) 0 0;max-height:90vh}.modal-sm,.modal-md,.modal-lg,.modal-xl{max-width:100%}}.create-tontine-form{display:flex;flex-direction:column;gap:20px}.frequence-options{display:flex;gap:10px;flex-wrap:wrap}.frequence-option{flex:1;min-width:100px;padding:12px 16px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-mid);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition)}.frequence-option:hover{border-color:var(--border-hover);color:var(--text)}.frequence-option.active{background:#e8a83826;border-color:var(--gold);color:var(--gold)}.color-options{display:flex;gap:12px}.color-option{width:40px;height:40px;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;color:#000}.color-option:hover{transform:scale(1.1)}.color-option.active{border-color:var(--text);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--gold)}.form-summary{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin-top:8px}.summary-item{display:flex;justify-content:space-between;align-items:center;font-size:14px}.summary-item:not(:last-child){margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}.summary-label{color:var(--text-dim)}.summary-value{font-weight:700;color:var(--text);font-family:var(--mono)}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;position:relative;overflow:hidden;display:flex;align-items:flex-start;gap:16px;transition:var(--transition)}.stat-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow)}.stat-card-accent{position:absolute;top:0;left:0;width:4px;height:100%}.stat-icon-wrapper{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-label{font-size:13px;color:var(--text-dim);font-weight:500;margin-bottom:8px}.stat-value{font-size:32px;font-weight:800;letter-spacing:-1px;font-family:var(--mono);color:var(--text);line-height:1}.stat-subtext{font-size:12px;color:var(--text-dim);margin-top:8px}.stat-trend{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:4px 8px;border-radius:6px;font-family:var(--mono)}.stat-trend.positive{color:var(--green);background:#69d86a1a}.stat-trend.negative{color:var(--red);background:#ff6b6b1a}.stat-card.loading{min-height:120px}.stat-card-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--surface) 0%,var(--surface2) 50%,var(--surface) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.stats-grid{grid-template-columns:1fr}}.tontine-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.tontine-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow)}.tontine-card-accent{position:absolute;top:0;left:0;width:4px;height:100%}.tontine-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px}.tontine-card-title{min-width:0;flex:1}.tontine-name{font-size:17px;font-weight:700;color:var(--text);margin:0 0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tontine-desc{font-size:13px;color:var(--text-dim);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tontine-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:16px}.tontine-stat{text-align:center}.tontine-stat-value{display:block;font-size:22px;font-weight:700;font-family:var(--mono);margin-bottom:4px}.tontine-stat-label{font-size:12px;color:var(--text-dim);font-weight:500}.tontine-progress{margin-bottom:20px}.progress-header{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim);margin-bottom:8px}.progress-value{font-family:var(--mono);font-weight:600}.progress-bar{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .5s ease}.tontine-card-footer{display:flex;align-items:center;justify-content:space-between}.participants-stack{display:flex}.participants-stack .avatar{border:2px solid var(--surface);margin-left:-10px}.participants-stack .avatar:first-child{margin-left:0}.avatar-more{background:var(--surface2)!important;color:var(--text-dim);font-size:10px;font-weight:600}.tontine-view-btn{opacity:0;transform:translate(-10px);transition:var(--transition)}.tontine-card:hover .tontine-view-btn{opacity:1;transform:translate(0)}.tontines-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media (max-width: 1200px){.tontines-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.tontines-grid{grid-template-columns:1fr}.tontine-view-btn{opacity:1;transform:none}}.donut-chart-wrapper{display:flex;align-items:center;gap:24px}.donut-chart-container{position:relative;flex-shrink:0}.donut-chart{transform:rotate(0)}.donut-segment{animation:fillSegment .8s ease-out forwards;opacity:0}@keyframes fillSegment{0%{opacity:0;stroke-dasharray:0,1000}to{opacity:1}}.donut-legend{display:flex;flex-direction:column;gap:10px}.legend-item{display:flex;align-items:center;gap:10px;font-size:13px}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-label{color:var(--text);font-weight:500}.legend-value{color:var(--text-dim);font-family:var(--mono);font-size:12px}@media (max-width: 480px){.donut-chart-wrapper{flex-direction:column;gap:16px}}.dashboard-page{padding-bottom:40px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.page-title{font-size:28px;font-weight:800;letter-spacing:-.5px;margin:0 0 4px}.page-subtitle{font-size:14px;color:var(--text-dim);margin:0}.section-title{font-size:16px;font-weight:700;display:flex;align-items:center;gap:10px;margin-bottom:20px;color:var(--text)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-header .section-title{margin-bottom:0}.dashboard-middle{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:28px 0}.dashboard-alerts{min-height:300px}.alerts-list{display:flex;flex-direction:column;gap:12px}.alert{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--radius-sm)}.alert-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.alert-icon.warning{background:#e8a83826;color:var(--gold)}.alert-icon.success{background:#69d86a26;color:var(--green)}.alert-content{flex:1;min-width:0}.alert-message{font-size:14px;color:var(--text);margin-bottom:4px;line-height:1.4}.alert-tontine{font-size:12px;color:var(--text-dim)}.dashboard-chart{display:flex;flex-direction:column}.chart-container{display:flex;justify-content:center;padding:20px 0}.chart-info{margin-top:auto}.chart-progress-header{display:flex;justify-content:space-between;font-size:13px;color:var(--text-dim);margin-bottom:8px}.chart-progress-value{font-family:var(--mono);font-weight:600;color:var(--gold)}.chart-subtext{font-size:13px;color:var(--text-dim);margin:12px 0 0;text-align:center}.dashboard-tontines{margin-top:28px}@media (max-width: 1200px){.dashboard-middle{grid-template-columns:1fr}}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:16px}}.tontines-page{padding-bottom:40px}.filters-bar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:28px;flex-wrap:wrap}.filter-tabs{display:flex;gap:8px;background:var(--surface);padding:6px;border-radius:var(--radius-sm);border:1px solid var(--border)}.filter-tab{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;color:var(--text-dim);background:transparent;border:none;cursor:pointer;transition:var(--transition);font-family:var(--font)}.filter-tab:hover{color:var(--text)}.filter-tab.active{background:var(--surface2);color:var(--text)}.search-box{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;min-width:280px;color:var(--text-dim);transition:var(--transition)}.search-box:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px #e8a8381a}.search-input{background:none;border:none;color:var(--text);font-family:var(--font);font-size:14px;flex:1;outline:none}.search-input::placeholder{color:var(--text-dim)}@media (max-width: 768px){.filters-bar{flex-direction:column;align-items:stretch}.filter-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.search-box{min-width:auto}}.tontine-detail-page{padding-bottom:40px}.detail-header{display:flex;align-items:center;gap:20px;margin-bottom:24px}.back-btn{display:flex;align-items:center;gap:8px;color:var(--text-dim);font-size:14px;font-weight:500;padding:10px 14px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:var(--transition);font-family:var(--font)}.back-btn:hover{color:var(--text);background:var(--surface2);border-color:var(--border-hover)}.detail-title-section{flex:1}.detail-name{font-size:28px;font-weight:800;letter-spacing:-.5px;margin:0 0 8px}.detail-meta{display:flex;align-items:center;gap:12px}.detail-info{font-size:14px;color:var(--text-dim)}.detail-stats{margin-bottom:28px}.tabs-container{margin-bottom:24px}.tab-content{animation:fadeIn .3s ease}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.tab-header .section-title{margin-bottom:0}.actions{display:flex;gap:8px}.wa-btn{color:#25d366;padding:8px}.wa-btn:hover{background:#25d3661a}.participant-cell{display:flex;align-items:center;gap:12px}.participant-name{font-weight:600;color:var(--text)}.amount{font-family:var(--mono);font-weight:600;color:var(--text)}.date-cell,.phone-cell{color:var(--text-dim);font-family:var(--mono);font-size:13px}.order-cell{color:var(--text-dim);font-family:var(--mono);font-weight:600}.tour-info{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#5b8def1a;border:1px solid rgba(91,141,239,.2);border-radius:var(--radius-sm);margin-bottom:20px;font-size:13px;color:var(--text-mid)}.tours-list{display:flex;flex-direction:column;gap:10px}.tour-item{display:flex;align-items:center;gap:14px;padding:16px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);transition:var(--transition)}.tour-item:hover{border-color:var(--border-hover)}.tour-item.current{border-color:var(--gold);background:#e8a8380d}.tour-item.done{opacity:.7}.tour-number{width:32px;height:32px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-dim);font-family:var(--mono)}.tour-item.current .tour-number{background:var(--gold);color:#000}.tour-item.done .tour-number{background:var(--green);color:#000}.tour-meta{flex:1;min-width:0}.tour-name{font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.current-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;background:var(--gold);color:#000;border-radius:10px}.tour-date{font-size:13px;color:var(--text-dim);margin-top:2px}.tour-amount{font-family:var(--mono);font-weight:700;font-size:15px;color:var(--text);margin-right:12px}.whatsapp-card{background:linear-gradient(135deg,#25d36614,#128c7e14);border:1px solid rgba(37,211,102,.2);border-radius:var(--radius);padding:20px;margin-bottom:20px}.whatsapp-header{display:flex;align-items:center;gap:14px}.whatsapp-icon{width:48px;height:48px;background:#25d366;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.whatsapp-title{font-size:18px;font-weight:700;margin:0 0 4px}.whatsapp-subtitle{font-size:13px;color:var(--text-dim);margin:0}.whatsapp-list{display:flex;flex-direction:column;gap:16px}.wa-card{padding:20px}.wa-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.wa-status{font-size:12px;color:var(--text-dim);margin-top:2px}.wa-preview{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;font-size:13px;color:var(--text-mid);white-space:pre-line;font-family:var(--font);line-height:1.5}@media (max-width: 768px){.detail-header{flex-direction:column;align-items:flex-start}.detail-name{font-size:22px}.detail-meta{flex-wrap:wrap}}.finances-page{padding-bottom:40px}.chart-card{margin:28px 0}.chart-wrapper{margin-top:20px}.distributions-card{margin-top:28px}.amount-cell{font-family:var(--mono);font-weight:600;color:var(--gold)}.notifications-page{padding-bottom:40px}.notifications-list{display:flex;flex-direction:column;gap:12px;margin-top:24px}.notification-item{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);position:relative}.notification-item:hover{border-color:var(--border-hover)}.notification-item.unread{background:#e8a83808;border-color:#e8a83833}.notification-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification-icon.warning{background:#e8a83826;color:var(--gold)}.notification-icon.success{background:#69d86a26;color:var(--green)}.notification-icon.info{background:#5b8def26;color:var(--blue)}.notification-content{flex:1;min-width:0}.notification-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.notification-title{font-size:15px;font-weight:700;color:var(--text);margin:0}.notification-time{font-size:12px;color:var(--text-dim);flex-shrink:0}.notification-message{font-size:14px;color:var(--text-mid);margin:0 0 8px;line-height:1.5}.notification-tontine{font-size:12px;color:var(--text-dim);font-weight:500}.notification-dot{width:8px;height:8px;background:var(--gold);border-radius:50%;position:absolute;top:24px;right:24px}.notification-item.read{opacity:.7}.notification-item.read .notification-title{font-weight:600}@media (max-width: 768px){.notification-header{flex-direction:column;align-items:flex-start;gap:4px}}.app{display:flex;min-height:100vh}.main-content{margin-left:280px;flex:1;min-height:100vh}.content-wrapper{padding:32px;max-width:1400px;margin:0 auto}@media (max-width: 768px){.main-content{margin-left:0}.content-wrapper{padding:20px}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0D0F14;--surface: #161A23;--surface2: #1E2433;--surface3: #252D3E;--border: #2A3447;--border-hover: #3A4660;--gold: #E8A838;--gold-dim: #B8832A;--gold-light: #F5C76B;--teal: #4ECDC4;--teal-dim: #3BA89E;--red: #FF6B6B;--red-dim: #E05555;--green: #69D86A;--green-dim: #4CB84D;--blue: #5B8DEF;--purple: #9B6EF3;--text: #F0F4FF;--text-dim: #7A8499;--text-mid: #B0BAD0;--text-light: #D4DAE8;--font: "Bricolage Grotesque", sans-serif;--mono: "DM Mono", monospace;--radius: 16px;--radius-sm: 10px;--radius-lg: 20px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--transition: all .2s ease}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fadeIn{animation:fadeIn .3s ease forwards}.animate-fadeInLeft{animation:fadeInLeft .3s ease forwards}.text-gold{color:var(--gold)}.text-teal{color:var(--teal)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-dim{color:var(--text-dim)}.bg-gold{background:var(--gold)}.bg-teal{background:var(--teal)}.bg-green{background:var(--green)}.bg-red{background:var(--red)}.bg-surface{background:var(--surface)}.bg-surface2{background:var(--surface2)}.font-mono{font-family:var(--mono)}::selection{background:#e8a8384d;color:var(--text)}
