@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,600;0,9..40,700&family=Outfit:wght@500;600;700&display=swap";:root{--palm-deep:#0d3d24;--palm:#1a5c3a;--palm-mid:#2d7a4f;--palm-light:#3d9b6a;--sand:#f4e9d4;--sand-dark:#e8d4b0;--gold:#c4a35a;--cream:#faf8f3;--text:#1a2f24;--muted:#5a7268;--card:#fff;--radius:14px;--shadow:0 12px 40px #0d3d241a;--font:"DM Sans", system-ui, sans-serif;--display:"Outfit", var(--font)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{font-family:var(--font);color:var(--text);background:var(--cream);line-height:1.6}a{color:var(--palm-mid)}h1,h2,h3{font-family:var(--display);color:var(--palm-deep)}.muted{color:var(--muted)}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.4rem;padding:.65rem 1.2rem;font-family:inherit;font-weight:600;text-decoration:none;transition:transform .15s,box-shadow .15s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg, var(--palm-mid), var(--palm));color:#fff;box-shadow:0 4px 14px #1a5c3a59}.btn-accent{background:var(--gold);color:var(--palm-deep)}.btn-ghost{color:var(--palm);background:#1a5c3a14}.btn-ghost-sm{color:var(--palm);cursor:pointer;background:0 0;border:1px solid #1a5c3a33;border-radius:8px;padding:.35rem .7rem;font-size:.85rem}.btn-sm{padding:.45rem .85rem;font-size:.9rem}.btn-lg{padding:.85rem 1.5rem;font-size:1.05rem}.btn-block{width:100%}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid #1a5c3a14;padding:1.5rem}.badge{border-radius:999px;padding:.2rem .6rem;font-size:.78rem;font-weight:600;display:inline-block}.badge-draft{color:#856404;background:#fff3cd}.badge-not_started{color:#495057;background:#e9ecef}.badge-pending_approval{color:#004085;background:#cce5ff}.badge-approved{color:#155724;background:#d4edda}.landing{background:radial-gradient(ellipse at 90% 10%, #3d9b6a26, transparent 50%), radial-gradient(ellipse at 10% 90%, #c4a35a1f, transparent 45%), linear-gradient(165deg, #e8f5ee 0%, var(--cream) 50%, var(--sand) 100%);min-height:100vh}.landing-header,.landing-hero,.landing-features,.landing-footer{max-width:1100px;margin:0 auto;padding:1.5rem}.landing-header{justify-content:space-between;align-items:center;display:flex}.landing-brand,.login-brand{color:var(--palm-deep);align-items:center;gap:.75rem;text-decoration:none;display:flex}.landing-brand strong,.login-brand span{font-family:var(--display);font-size:1.1rem}.landing-brand span{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;display:block}.landing-hero{grid-template-columns:1.2fr .8fr;align-items:center;gap:2rem;padding-top:2rem;padding-bottom:3rem;display:grid}@media (width<=800px){.landing-hero{grid-template-columns:1fr}}.eyebrow{color:var(--palm-mid);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:600}.landing-hero h1{margin:.5rem 0 1rem;font-size:clamp(2rem,4vw,2.8rem);line-height:1.15}.lead{color:var(--muted);max-width:52ch;font-size:1.1rem}.hero-actions{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.hero-card{border-radius:var(--radius);box-shadow:var(--shadow);background:#ffffffd9;border:1px solid #c4a35a40;padding:1.75rem}.hero-card ul{margin:0;padding-left:1.2rem;line-height:2}.landing-features{grid-template-columns:repeat(3,1fr);gap:1.25rem;padding-bottom:3rem;display:grid}@media (width<=800px){.landing-features{grid-template-columns:1fr}}.landing-footer{text-align:center;color:var(--muted);padding-bottom:2rem}.login-page{background:linear-gradient(160deg, #e8f5ee, var(--sand));place-items:center;min-height:100vh;padding:1rem;display:grid}.login-card{border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow);background:#fff;padding:2rem}.login-card h1{margin:1rem 0 .25rem;font-size:1.5rem}.login-card label{margin:1rem 0;font-size:.88rem;font-weight:600;display:block}.login-card input{width:100%;font:inherit;border:1px solid #1a5c3a40;border-radius:10px;margin-top:.35rem;padding:.65rem .85rem}.login-back{text-align:center;margin-top:1.25rem;font-size:.9rem}.app-shell{min-height:100vh;display:flex}.sidebar{background:linear-gradient(180deg, var(--palm-deep), var(--palm));color:#fff;flex-direction:column;flex-shrink:0;width:260px;padding:1.25rem;display:flex}.sidebar-brand{color:#fff;align-items:center;gap:.65rem;margin-bottom:.75rem;text-decoration:none;display:flex}.sidebar-brand strong{font-family:var(--display);display:block}.sidebar-brand span{opacity:.75;text-transform:uppercase;letter-spacing:.06em;font-size:.7rem}.org-badge{background:#ffffff1f;border-radius:8px;margin:0 0 1rem;padding:.4rem .65rem;font-size:.82rem}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;display:flex}.sidebar-nav a{color:#ffffffe0;border-radius:8px;padding:.55rem .75rem;font-weight:500;text-decoration:none}.sidebar-nav a:hover{background:#ffffff1f}.sidebar-foot{border-top:1px solid #ffffff26;margin-top:auto;padding-top:1rem}.user-pill{opacity:.85;margin-bottom:.5rem;font-size:.85rem;display:block}.main-content{background:radial-gradient(ellipse at 100% 0%, #3d9b6a0f, transparent 40%), var(--cream);flex:1;padding:2rem;overflow-x:auto}@media (width<=900px){.app-shell{flex-direction:column}.sidebar{width:100%}.sidebar-nav{flex-flow:wrap}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.page-header h1{margin:0}.export-actions{flex-wrap:wrap;gap:.5rem;display:flex}.dashboard-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}}.card-highlight{text-align:center;flex-direction:column;align-items:center;gap:.75rem;display:flex}.stat{color:var(--palm);margin:0;font-size:2.5rem;font-weight:700}.link-list{margin:0;padding:0;list-style:none}.link-list li{margin:.5rem 0}.progress-ring{position:relative}.progress-ring svg{transform:rotate(0)}.ring-bg{stroke:#1a5c3a1f}.ring-fg{stroke:var(--palm-light);transition:stroke-dashoffset .6s}.progress-label{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.progress-label strong{color:var(--palm-deep);font-size:1.6rem}.progress-label span{color:var(--muted);font-size:.75rem}.wizard-list{flex-direction:column;gap:1rem;display:flex}.wizard-step{align-items:flex-start;gap:1rem;display:flex}.step-num{background:var(--palm);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-weight:700;display:grid}.step-body h3{margin:0 0 .35rem}.step-actions{margin-top:.75rem}.clause-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:1rem;display:grid}.clause-card{background:#1a5c3a0a;border-radius:10px;padding:1rem}.clause-num{color:var(--gold);font-size:.9rem;font-weight:700}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.toolbar input,.toolbar select{font:inherit;border:1px solid #1a5c3a33;border-radius:8px;padding:.5rem .75rem}.control-list{margin-top:1rem}.control-row{border-bottom:1px solid #0000000f}.control-head{text-align:left;cursor:pointer;width:100%;font:inherit;background:0 0;border:none;grid-template-columns:5rem 1fr auto;align-items:center;gap:.75rem;padding:.75rem 0;display:grid}.control-id{color:var(--palm);font-weight:700}.control-cat{color:var(--muted);font-size:.78rem}.control-desc{color:var(--muted);margin:0;padding:0 0 1rem 5.75rem}.soa-table-wrap{overflow-x:auto}.soa-table{border-collapse:collapse;width:100%;font-size:.9rem}.soa-table th,.soa-table td{text-align:left;vertical-align:top;border-bottom:1px solid #0000000f;padding:.6rem .5rem}.soa-table th{color:var(--palm-deep);font-size:.8rem}.soa-input{width:100%;min-width:120px;font:inherit;border:1px solid #ddd;border-radius:6px;padding:.35rem}.soa-table select{font:inherit;border:1px solid #ddd;border-radius:6px;padding:.35rem}.doc-editor{resize:vertical;border:1px solid #1a5c3a33;border-radius:10px;width:100%;padding:1rem;font-family:ui-monospace,monospace;font-size:.9rem;line-height:1.55}.editor-actions{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.meta-bar{flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem;font-size:.9rem;display:flex}.form-msg{color:var(--palm-mid);margin-top:.75rem;font-size:.9rem}.alert{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem}.alert-error{color:#721c24;background:#f8d7da}.alert-success{color:#155724;background:#d4edda}.admin-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}@media (width<=800px){.admin-grid{grid-template-columns:1fr}}.admin-grid label{margin:.75rem 0;font-size:.88rem;font-weight:600;display:block}.admin-grid input,.admin-grid select{width:100%;font:inherit;border:1px solid #ccc;border-radius:8px;margin-top:.3rem;padding:.55rem}.admin-list{padding:0;list-style:none}.admin-list li{border-bottom:1px solid #eee;padding:.4rem 0}.logo-preview{margin:1rem 0}.logo-preview img{object-fit:contain;max-width:200px;max-height:80px}.logo-placeholder{width:120px;height:60px;color:var(--muted);background:#f0f0f0;border-radius:8px;place-items:center;font-size:.85rem;display:grid}.org-select{width:100%;font:inherit;background:#ffffffe6;border:none;border-radius:8px;margin-bottom:.75rem;padding:.45rem}.loading-screen{min-height:100vh;color:var(--palm);place-items:center;font-weight:600;display:grid}.lang-switch{background:#fff;border:1px solid #1a5c3a33;border-radius:8px;display:inline-flex;overflow:hidden}.lang-switch button{cursor:pointer;color:var(--muted);background:0 0;border:none;padding:.35rem .65rem;font-size:.8rem;font-weight:600}.lang-switch button.active{background:var(--palm);color:#fff}.sidebar-lang.lang-switch{background:#ffffff1a;border-color:#ffffff40;width:100%;margin-bottom:.75rem}.sidebar-lang.lang-switch button{color:#ffffffd9;flex:1}.sidebar-lang.lang-switch button.active{color:#fff;background:#ffffff38}.landing-header-actions{align-items:center;gap:.75rem;display:flex}.login-top{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.activity-list{margin:0;padding:0;list-style:none}.activity-list li{border-bottom:1px solid #eee;justify-content:space-between;gap:1rem;padding:.5rem 0;display:flex}.page-header-actions{flex-wrap:wrap;gap:.5rem;display:flex}.risk-summary-grid{grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem;display:grid}.risk-level-card{text-align:center;cursor:pointer;border:2px solid #0000;padding:1rem}.risk-level-card.active{border-color:var(--palm)}.risk-level-count{font-size:1.75rem;font-weight:700;font-family:var(--display);display:block}.risk-level-critical{background:#fde8ea}.risk-level-high{background:#fff0e0}.risk-level-medium{background:#fff8e1}.risk-level-low{background:#e8f5e9}.risk-matrix-card h2{margin-top:0;font-size:1.1rem}.risk-matrix-hint{margin-bottom:.75rem;font-size:.85rem}.risk-matrix-wrap{overflow-x:auto}.risk-matrix{border-collapse:collapse;margin:0 auto}.risk-matrix th,.risk-matrix td{text-align:center;padding:.25rem}.risk-matrix-cell{cursor:pointer;border:none;border-radius:8px;width:3rem;height:3rem;font-family:inherit;font-weight:700}.risk-matrix-cell.active{outline:3px solid var(--palm-deep)}.risk-matrix-low{background:#c8e6c9}.risk-matrix-medium{background:#fff9c4}.risk-matrix-high{background:#ffcc80}.risk-matrix-critical{background:#ef9a9a}.risk-matrix-axis-x,.risk-matrix-axis-y{color:var(--muted);text-align:center;margin:.25rem 0;font-size:.8rem}.badge-risk-low{color:#155724;background:#d4edda}.badge-risk-medium{color:#856404;background:#fff3cd}.badge-risk-high{color:#8a4b00;background:#ffe5b4}.badge-risk-critical{color:#721c24;background:#f8d7da}.risk-form-grid,.risk-detail-form .risk-form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.risk-form-grid label,.risk-detail-form label{flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:600;display:flex}.risk-form-grid .span-2{grid-column:span 2}.risk-form-grid input,.risk-form-grid select,.risk-form-grid textarea,.risk-detail-form input,.risk-detail-form select,.risk-detail-form textarea{font:inherit;border:1px solid #1a5c3a33;border-radius:8px;padding:.5rem}.risk-section-title{color:var(--palm-mid);border-top:1px solid #eee;margin:.5rem 0 0;padding-top:1rem;font-size:1rem}.risk-form{margin-bottom:1rem}.risk-table td{font-size:.9rem}@media (width<=768px){.risk-summary-grid{grid-template-columns:repeat(2,1fr)}.risk-form-grid{grid-template-columns:1fr}.risk-form-grid .span-2{grid-column:span 1}}
