/* ---- OVERRIDES for shared pages (wider layout) ---- */
body{line-height:1.6}
.page{max-width:800px;margin:0 auto;padding:40px 24px}

/* ---- HEADER ---- */
.header{text-align:center;margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.header-label{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.header h1{font-size:1.8rem;font-weight:700;margin:8px 0 4px}
.header .sub{font-size:.88rem;color:var(--text2);max-width:520px;margin:0 auto}

/* ---- STATS ROW ---- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:32px}
.stat-box{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center}
.stat-box .num{font-family:'JetBrains Mono',monospace;font-size:1.6rem;font-weight:700;line-height:1}
.stat-box .label{font-size:.68rem;color:var(--text2);margin-top:4px}

/* ---- SECTION DIVIDER ---- */
.section-div{display:flex;align-items:center;gap:12px;margin:36px 0 16px}
.section-div .icon{font-size:1.2rem}
.section-div .title{font-size:1rem;font-weight:600;color:var(--al)}
.section-div::after{content:'';flex:1;height:1px;background:var(--border)}

/* ---- BUTTONS ---- */
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin:24px 0}
.btn{padding:10px 20px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.btn:hover{border-color:var(--al);color:var(--al)}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:#5558e6}
.btn-green{background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.3);color:var(--green)}
.btn-green:hover{background:rgba(34,197,94,.25)}
.btn-danger{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:var(--red)}
.btn-danger:hover{background:rgba(239,68,68,.2)}
.btn-icon{width:34px;height:34px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s}
.btn-icon:hover{border-color:var(--al);color:var(--al)}
.btn-icon.danger:hover{border-color:var(--red);color:var(--red)}

/* ---- LINK CARDS ---- */
.link-card{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:10px;text-decoration:none;color:var(--text);transition:all .2s;margin-bottom:8px}
.link-card:hover{border-color:var(--al);transform:translateY(-1px);text-decoration:none}
.link-card .lc-icon{font-size:1.2rem}
.link-card .lc-info{flex:1}
.link-card .lc-title{font-size:.85rem;font-weight:600}
.link-card .lc-desc{font-size:.68rem;color:var(--muted)}
.link-card .lc-arrow{color:var(--muted);font-size:.8rem}

/* ---- CHECK ITEMS ---- */
.check-list{list-style:none}
.check-item{display:flex;align-items:flex-start;gap:8px;padding:7px 10px;background:var(--card);border:1px solid var(--border);border-radius:8px;margin-bottom:4px;font-size:.78rem;color:var(--text2);transition:all .15s;cursor:pointer}
.check-item:hover{border-color:var(--al)}
.check-item.done{opacity:.5;text-decoration:line-through;color:var(--muted)}
.check-box{width:16px;height:16px;border:2px solid var(--border);border-radius:4px;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.check-item.done .check-box{border-color:var(--green);background:rgba(34,197,94,.2);color:var(--green)}
.check-item.done .check-box::after{content:"\2713";font-size:.65rem}
.check-text{flex:1}
.check-text strong{color:#ddd;font-weight:600}

/* ---- PROGRESS BAR ---- */
.progress-wrap{margin-bottom:24px}
.progress-label{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted);margin-bottom:4px}
.progress-bar{height:8px;background:#1a1a2e;border-radius:4px;overflow:hidden}
.progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--green),var(--cyan));transition:width .3s}

/* ---- FORM STYLES ---- */
.form-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:16px}
.form-row{margin-bottom:14px}
.form-label{display:block;font-size:.72rem;font-weight:600;color:var(--text2);margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em}
.form-hint{font-size:.65rem;color:var(--muted);margin-top:2px}
.form-input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.85rem;font-family:inherit}
.form-input:focus{outline:none;border-color:var(--al)}
.form-input::placeholder{color:var(--muted)}
textarea.form-input{min-height:60px;resize:vertical}
.form-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.required::after{content:' *';color:var(--red)}

/* ---- TAG SELECTION (multi-select) ---- */
.tag-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.tag-option{padding:6px 12px;border-radius:6px;background:var(--bg);border:1px solid var(--border);cursor:pointer;font-size:.75rem;font-weight:500;color:var(--text2);transition:all .2s;user-select:none}
.tag-option:hover{border-color:var(--al);color:var(--al)}
.tag-option.selected{border-color:var(--accent);background:rgba(99,102,241,.15);color:var(--al)}
.tag-cat-green .tag-option.selected{border-color:var(--green);background:rgba(34,197,94,.12);color:var(--green)}
.tag-cat-green .tag-option:hover{border-color:var(--green);color:var(--green)}
.tag-cat-blue .tag-option.selected{border-color:var(--cyan);background:rgba(6,182,212,.12);color:var(--cyan)}
.tag-cat-blue .tag-option:hover{border-color:var(--cyan);color:var(--cyan)}
.tag-cat-orange .tag-option.selected{border-color:var(--orange);background:rgba(245,158,11,.12);color:var(--orange)}
.tag-cat-orange .tag-option:hover{border-color:var(--orange);color:var(--orange)}
.tag-cat-purple .tag-option.selected{border-color:var(--pink);background:rgba(236,72,153,.12);color:var(--pink)}
.tag-cat-purple .tag-option:hover{border-color:var(--pink);color:var(--pink)}

/* ---- RADIO CARDS (single-select) ---- */
.radio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:4px}
.radio-card{padding:10px 12px;border-radius:8px;background:var(--bg);border:1px solid var(--border);cursor:pointer;text-align:center;font-size:.78rem;font-weight:500;color:var(--text2);transition:all .2s;user-select:none}
.radio-card:hover{border-color:var(--al);color:var(--al)}
.radio-card.selected{border-color:var(--accent);background:rgba(99,102,241,.15);color:var(--al)}
.radio-card .rc-icon{display:block;font-size:1.4rem;margin-bottom:4px}

/* ---- PHASE BADGES ---- */
.phase-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.62rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.phase-graine{background:rgba(34,197,94,.15);color:var(--green)}
.phase-pousse{background:rgba(6,182,212,.15);color:var(--cyan)}
.phase-racine{background:rgba(245,158,11,.15);color:var(--orange)}
.phase-porteur{background:rgba(236,72,153,.15);color:var(--pink)}

/* ---- TYPE / PILLAR / STATUS BADGES ---- */
.type-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.62rem;font-weight:600;background:rgba(99,102,241,.1);color:var(--al)}
.pillar-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.62rem;font-weight:600;background:rgba(236,72,153,.1);color:var(--pink)}
.status-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.62rem;font-weight:600;background:rgba(34,197,94,.1);color:var(--green)}

/* ---- TAG PILLS (display only) ---- */
.tag-list{display:flex;flex-wrap:wrap;gap:4px;margin:8px 0}
.tag-pill{padding:3px 8px;border-radius:4px;font-size:.62rem;background:rgba(99,102,241,.08);color:var(--muted)}

/* ---- FILTER BAR ---- */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;align-items:center}
.filter-tabs{display:flex;flex-wrap:wrap;gap:4px}
.filter-tab{padding:6px 12px;border-radius:6px;background:var(--bg);border:1px solid var(--border);cursor:pointer;font-size:.72rem;font-weight:500;color:var(--text2);transition:all .2s;user-select:none}
.filter-tab:hover{border-color:var(--al);color:var(--al)}
.filter-tab.active{border-color:var(--accent);background:rgba(99,102,241,.15);color:var(--al)}
.search-input{flex:1;min-width:180px;padding:8px 12px;border-radius:6px;background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:.78rem}
.search-input:focus{border-color:var(--accent);outline:none}

/* ---- EMPTY STATE ---- */
.empty-state{text-align:center;padding:40px 20px;color:var(--muted)}
.empty-state .emoji{font-size:2.5rem;margin-bottom:12px}
.empty-state p{font-size:.85rem;margin-bottom:16px}

/* ---- ADD FORM (inline add rows) ---- */
.add-form{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.add-form .form-input{flex:1;min-width:120px;padding:8px 10px;font-size:.75rem}
.add-form select{padding:8px 10px;border-radius:6px;background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:.75rem}
.add-form select:focus{border-color:var(--accent);outline:none}

/* ---- ALERT BOX ---- */
.alert-box{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:16px;margin-bottom:20px;display:flex;align-items:center;gap:12px;font-size:.82rem;color:var(--orange)}

/* ---- TOAST ---- */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);padding:10px 24px;border-radius:8px;background:var(--green);color:#fff;font-size:.82rem;font-weight:500;opacity:0;transition:opacity .3s;pointer-events:none;z-index:9997;max-width:calc(100% - 32px);text-align:center}
.toast.show{opacity:1}
.toast.error{background:var(--red)}

/* ---- FOOTER ---- */
.footer{text-align:center;margin-top:40px;padding-top:20px;border-top:1px solid var(--border)}
.footer p{font-size:.72rem;color:var(--muted)}

/* ---- RESPONSIVE ---- */
@media(max-width:768px){
    .toast{bottom:100px}
}
@media(max-width:600px){
    .stat-row{grid-template-columns:repeat(2,1fr)}
    .form-grid2{grid-template-columns:1fr}
    .radio-grid{grid-template-columns:repeat(2,1fr)}
    .filter-bar{flex-direction:column}
    .add-form{flex-direction:column}
}
