@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap');

*{margin:0;padding:0;box-sizing:border-box}

:root,[data-theme="light"]{
  --bg:#fff;--bg2:#f5f5f5;--bg3:#ebebeb;
  --text:#111;--text2:#666;--text3:#999;
  --border:#e0e0e0;--border2:#ccc;
  --accent:#c9a84c;--accent-hover:#b8973d;
  --green:#22c55e;--green-bg:#f0fdf4;
  --blue:#3b82f6;--blue-bg:#eff6ff;
  --amber:#f59e0b;--amber-bg:#fffbeb;
  --red:#ef4444;--red-bg:#fef2f2;
  --purple:#8b5cf6;--purple-bg:#f5f3ff;
  --accent-bg:#fdf8ed;
  --shadow:0 1px 3px rgba(0,0,0,.08);
  --shadow-lg:0 4px 12px rgba(0,0,0,.1);
}

[data-theme="dark"]{
  --bg:#0f0f0f;--bg2:#1a1a1a;--bg3:#252525;
  --text:#e5e5e5;--text2:#999;--text3:#666;
  --border:#2a2a2a;--border2:#333;
  --accent:#c9a84c;--accent-hover:#d4b65e;
  --green:#22c55e;--green-bg:#0a2618;
  --blue:#3b82f6;--blue-bg:#0a1929;
  --amber:#f59e0b;--amber-bg:#1a1400;
  --red:#ef4444;--red-bg:#1a0a0a;
  --purple:#a78bfa;--purple-bg:#1a0f2e;
  --accent-bg:#1a1608;
  --shadow:0 1px 3px rgba(0,0,0,.3);
  --shadow-lg:0 4px 12px rgba(0,0,0,.4);
}

body{
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,monospace;
  font-size:15px;line-height:1.6;color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;
}

a{color:var(--text);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent)}

/* Nav */
.nav{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border);backdrop-filter:blur(8px)}
.nav-inner{max-width:960px;margin:0 auto;padding:.75rem 2rem;display:flex;justify-content:space-between;align-items:center}
.nav-logo{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;display:flex;flex-direction:column;line-height:1.2}
.nav-logo .phonetic{font-size:.55rem;font-weight:400;color:var(--text3);letter-spacing:.02em;font-family:'Noto Sans',system-ui,sans-serif;font-style:italic}
.nav-right{display:flex;align-items:center;gap:1.5rem}
.nav-right a{color:var(--text2);font-size:.85rem}
.nav-right a:hover{color:var(--text)}
.nav-profile{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--text3)!important;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-profile:hover{color:var(--accent)!important}
.profile-icon{font-size:.7rem}
.theme-toggle{background:none;border:1px solid var(--border);color:var(--text2);cursor:pointer;padding:.3rem .6rem;border-radius:4px;font-family:inherit;font-size:.8rem}
.theme-toggle:hover{border-color:var(--text2);color:var(--text)}

/* Container */
.container{max-width:960px;margin:0 auto;padding:2rem}

/* Landing Hero */
.hero{text-align:center;padding:6rem 2rem 4rem}
.hero h1{font-size:3rem;font-weight:700;letter-spacing:-.03em;margin-bottom:1rem}
.hero p{color:var(--text2);font-size:1rem;max-width:500px;margin:0 auto 1rem}
.hero p:last-of-type{margin-bottom:2.5rem}
.hero .hero-slogan{color:var(--accent);font-size:1.2rem;font-weight:600;letter-spacing:-.01em;margin-bottom:.5rem}

/* Features */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;padding:3rem 2rem;max-width:960px;margin:0 auto}
.feature{text-align:center}
.feature-icon{font-size:1.5rem;margin-bottom:.75rem}
.feature h3{font-size:1rem;font-weight:600;margin-bottom:.4rem}
.feature p{color:var(--text2);font-size:.85rem}

/* Steps */
.steps{max-width:960px;margin:0 auto;padding:4rem 2rem}
.steps h2{text-align:center;font-size:1.5rem;margin-bottom:3rem;font-weight:600}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.step{text-align:center}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border:2px solid var(--accent);border-radius:50%;font-weight:700;color:var(--accent);margin-bottom:1rem;font-size:1rem}
.step h3{font-size:.95rem;font-weight:600;margin-bottom:.4rem}
.step p{color:var(--text2);font-size:.85rem}

/* Landing - Dashboard preview */
.landing-preview{max-width:960px;margin:0 auto;padding:3rem 2rem 4rem;text-align:center}
.landing-preview h2{font-size:1.5rem;font-weight:700;margin-bottom:.4rem}
.landing-preview-sub{color:var(--text2);font-size:.9rem;margin-bottom:2.5rem}
.preview-window{border:1px solid var(--border);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-lg);text-align:left;background:var(--bg)}
.preview-chrome{display:flex;gap:6px;padding:.6rem .8rem;background:var(--bg2);border-bottom:1px solid var(--border)}
.preview-chrome span{width:10px;height:10px;border-radius:50%;background:var(--border2)}
.preview-body{padding:1rem}
.preview-filters{display:flex;gap:.4rem;margin-bottom:1rem;flex-wrap:wrap}
.preview-pill{padding:.3rem .6rem;border:1px solid var(--border);border-radius:4px;font-size:.75rem;color:var(--text2)}
.preview-search{padding:.3rem .6rem;border:1px solid var(--border);border-radius:4px;font-size:.75rem;color:var(--text3);flex:1;min-width:80px}
.preview-table{border:1px solid var(--border);border-radius:6px;overflow:hidden}
.preview-row{display:grid;grid-template-columns:7.5rem 2rem 5.5rem 2fr 1.5fr;padding:.5rem .6rem;align-items:center;font-size:.78rem;border-bottom:1px solid var(--border)}
.preview-row:last-child{border-bottom:none}
.preview-row-head{background:var(--bg2);font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);font-weight:600}
.preview-row-head span{border-right:1px solid var(--border);padding-right:.4rem}
.preview-row-head span:last-child{border-right:none}

/* Landing - Feature cards */
.landing-features{max-width:960px;margin:0 auto;padding:2rem 2rem 4rem}
.landing-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.landing-fcard{border:1px solid var(--border);border-radius:6px;padding:1.5rem;transition:border-color .2s,box-shadow .2s}
.landing-fcard:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.landing-fcard-icon{font-size:1.2rem;margin-bottom:.6rem;color:var(--accent)}
.landing-fcard h3{font-size:.9rem;font-weight:600;margin-bottom:.35rem}
.landing-fcard p{font-size:.8rem;color:var(--text2);line-height:1.55}
.landing-fcard-badges{display:flex;gap:.3rem;flex-wrap:wrap;margin-top:.75rem}
.landing-fcard-dots{display:flex;gap:1rem;margin-top:.75rem;font-size:.75rem;color:var(--text2)}
.landing-fcard-dots span{display:flex;align-items:center;gap:.3rem}

/* Landing - How it works (lifecycle) */
.landing-how{max-width:960px;margin:0 auto;padding:4rem 2rem}
.landing-how h2{text-align:center;font-size:1.5rem;font-weight:700;margin-bottom:.3rem}
.landing-how-sub{text-align:center;color:var(--text2);font-size:.9rem;margin-bottom:2.5rem}
.how-pipeline{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:3rem;flex-wrap:wrap}
.how-step{display:flex;align-items:center;gap:.5rem}
.how-arrow{color:var(--text3);font-size:1rem}
.how-details{display:flex;flex-direction:column;gap:1.25rem}
.how-card{display:grid;grid-template-columns:2rem 1fr;gap:0 1rem;padding:1.25rem;border:1px solid var(--border);border-radius:6px;transition:border-color .2s}
.how-card:hover{border-color:var(--accent)}
.how-card-num{grid-row:1/3;font-size:1.1rem;font-weight:700;color:var(--accent);padding-top:.1rem}
.how-card h3{font-size:.95rem;font-weight:600;margin-bottom:.3rem}
.how-card p{font-size:.82rem;color:var(--text2);line-height:1.6}
.how-card p strong{color:var(--text);font-weight:600}

/* Landing - Pain point callout */
.landing-callout{max-width:960px;margin:0 auto;padding:3rem 2rem}
.callout-inner{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.callout-old,.callout-new{padding:1.5rem;border-radius:6px;border:1px solid var(--border)}
.callout-old{background:var(--bg2)}
.callout-new{background:var(--accent-bg);border-color:var(--accent)}
.callout-old h3,.callout-new h3{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem;color:var(--text2)}
.callout-new h3{color:var(--accent)}
.callout-old ul,.callout-new ul{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.callout-old li,.callout-new li{font-size:.82rem;line-height:1.5}
.callout-old li{color:var(--text3)}
.callout-new li{color:var(--text)}

/* Landing - CTA */
.landing-cta{text-align:center;padding:4rem 2rem;border-top:1px solid var(--border);margin-top:2rem}
.landing-cta h2{font-size:1.3rem;font-weight:700;margin-bottom:.4rem}
.landing-cta p{color:var(--text2);font-size:.9rem;margin-bottom:1.5rem}

/* Coming soon tag */
.soon{display:inline-block;font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:var(--accent-bg);padding:.1rem .35rem;border-radius:3px;vertical-align:middle;margin-left:.25rem}

/* Footer */
.footer{border-top:1px solid var(--border);margin-top:6rem;padding:3rem 2rem 2rem}
.footer-inner{max-width:960px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:3rem;margin-bottom:2rem}
.footer-brand{font-weight:700;font-size:1rem;margin-bottom:.5rem}
.footer-tagline{color:var(--text2);font-size:.8rem}
.footer-col h4{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text2);margin-bottom:.75rem}
.footer-col a{display:block;color:var(--text2);font-size:.85rem;padding:.2rem 0;transition:color .2s}
.footer-col a:hover{color:var(--text)}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.5rem;color:var(--text3);font-size:.8rem;display:flex;justify-content:space-between}

/* Buttons */
.btn{display:inline-block;padding:.6rem 1.25rem;border-radius:4px;font-weight:600;font-size:.85rem;font-family:inherit;cursor:pointer;transition:all .2s;border:none;text-align:center}
.btn-primary{background:var(--accent);color:#111}
.btn-primary:hover{background:var(--accent-hover);color:#111}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--text2);color:var(--text)}
.btn-ghost{background:transparent;color:var(--text2);padding:.4rem .75rem}
.btn-ghost:hover{color:var(--text)}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{opacity:.85;color:#fff}
.btn-sm{padding:.4rem .8rem;font-size:.8rem}
.btn-block{width:100%;display:block}

/* Cards */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:1.5rem;transition:border-color .2s}
.card:hover{border-color:var(--border2)}

/* Badges */
.badge{display:inline-block;padding:.15rem .5rem;border-radius:3px;font-size:.75rem;font-weight:600}
.badge-draft{background:var(--bg3);color:var(--text2)}
.badge-template{background:#eab308;color:#111}
.badge-shared{background:var(--blue);color:#fff}
.badge-negotiating{background:var(--amber);color:#111}
.badge-file,.badge-approved{background:var(--purple);color:#fff}
.badge-completed{background:var(--green);color:#fff}

/* Dashboard - Status bar */
/* Dashboard filter bar and toolbar */

/* Dashboard - Toolbar */
.dash-toolbar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.dash-create{display:flex;gap:.4rem;align-items:center}
.dash-filters{display:flex;gap:.4rem;align-items:center;margin-left:auto}
.dash-input{border:1px solid var(--border);padding:.4rem .6rem;border-radius:4px;font-family:inherit;font-size:.8rem;background:var(--bg);color:var(--text);width:150px}
.dash-input:focus{border-color:var(--accent);outline:none}
.dash-input-sm{width:110px}
.dash-select{border:1px solid var(--border);padding:.4rem .5rem;border-radius:4px;background:var(--bg);color:var(--text);font-family:inherit;font-size:.8rem}
.dash-select.active-filter{border-color:var(--accent);background:var(--accent-bg);color:var(--accent);font-weight:600}

/* Dashboard - Table */
.dash-table{border:1px solid var(--border);border-radius:6px;overflow:hidden}
.dash-table-head{display:grid;grid-template-columns:7.5rem 2.5rem 6.5rem 2.5fr 1fr 1.5fr 2fr .8fr;padding:.5rem .75rem;background:var(--bg2);border-bottom:1px solid var(--border);font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);font-weight:600}
.dash-table-head>span{padding:0 .35rem}
.dash-table-head>span:not(:last-child){border-right:1px solid var(--border)}
.dash-table-row{display:grid;grid-template-columns:7.5rem 2.5rem 6.5rem 2.5fr 1fr 1.5fr 2fr .8fr;padding:.6rem .75rem;border-bottom:1px solid var(--border);align-items:center;font-size:.85rem;transition:background .1s}
.dash-table-row>span{padding:0 .35rem}
.dash-table-row>span:not(:last-child){border-right:1px solid transparent}
.dash-table-row:last-child,.dash-detail-row:last-child{border-bottom:none}
.dash-table-row:hover{background:var(--bg2)}
.dash-table-row a{color:var(--text);font-weight:500}
.dash-table-row a:hover{color:var(--accent)}
.col-date{display:flex;flex-direction:column;gap:.1rem}
.date-ago{font-size:.6rem;color:var(--text3);font-style:italic}

/* Health indicators */
.health-dot{font-size:.55rem;line-height:1;position:relative;cursor:default}
.health-active{color:var(--green)}
.health-expiring{color:var(--amber)}
.health-expired{color:var(--red,#ef4444)}
.health-inactive{color:var(--red)}
.health-dot[data-tip]:hover::after{content:attr(data-tip);position:absolute;left:0;top:calc(100% + 4px);white-space:nowrap;background:var(--text);color:var(--bg);font-size:.65rem;padding:.25rem .5rem;border-radius:3px;z-index:10;pointer-events:none}

/* Filter bar */
.dash-filter-bar{display:flex;gap:.4rem;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap}
.mono-sm{font-size:.7rem;color:var(--text2);letter-spacing:-.01em}
.text-muted{color:var(--text3);font-size:.8rem}
.tag{display:inline-block;padding:.1rem .4rem;background:var(--bg3);border-radius:3px;font-size:.7rem;color:var(--text2)}
.col-actions{display:flex;gap:.25rem;justify-content:flex-end}

/* Dashboard - Lifecycle */
.dash-lifecycle{margin:2rem 0;padding:1.25rem;border:1px solid var(--border);border-radius:6px;background:var(--bg2)}
.dash-lifecycle h3{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text2);margin-bottom:.75rem}
.lifecycle-steps{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}
.lifecycle-step{display:flex;align-items:center;gap:.25rem}
.lifecycle-arrow{color:var(--text3);font-size:.75rem}
.lifecycle-hint{font-size:.7rem;color:var(--text3);margin-top:.75rem;font-style:italic}

/* Dashboard - WIP panels */
.dash-wip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.5rem}
.dash-wip{padding:1rem}
.dash-wip h4{font-size:.85rem;font-weight:600;margin-bottom:.35rem;color:var(--text)}
.dash-wip p{font-size:.78rem;color:var(--text3);line-height:1.5}

/* Badge additions */


/* Forms */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.4rem;color:var(--text2)}
.form-input,.form-textarea,.form-select{
  width:100%;padding:.6rem 0;background:transparent;border:none;
  border-bottom:1px solid var(--border);color:var(--text);font-family:inherit;
  font-size:.95rem;outline:none;transition:border-color .2s;
}
.form-input:focus,.form-textarea:focus{border-color:var(--accent)}
.form-textarea{min-height:100px;resize:vertical;border:1px solid var(--border);border-radius:4px;padding:.6rem}
.form-textarea:focus{border-color:var(--accent)}
.form-hint{font-size:.78rem;color:var(--text3);margin-top:.2rem}

/* Page header */
.page-header{margin-bottom:2rem}
.page-header h1{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}
.page-header p{color:var(--text2);font-size:.9rem}

/* Clause editor */
.clause-list{display:flex;flex-direction:column;gap:1.5rem}
.clause-card{border-left:3px solid var(--border)}
.clause-card.has-selection{border-left-color:var(--amber)}
.clause-card.accepted{border-left-color:var(--green)}
.clause-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.clause-header h3{font-size:1rem;font-weight:600}
.clause-actions{display:flex;gap:.5rem}
.alt-tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
.alt-tab{padding:.3rem .75rem;border:1px solid var(--border);border-radius:3px;font-size:.8rem;cursor:pointer;transition:all .2s;font-family:inherit;background:transparent;color:var(--text2)}
.alt-tab:hover,.alt-tab.active{border-color:var(--accent);color:var(--accent)}
.alt-tab.default{font-weight:600}
.alt-content{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1rem;font-size:.9rem;line-height:1.7;white-space:pre-wrap}

/* Counterparty clause selection */
.clause-option{border:1px solid var(--border);border-radius:4px;padding:1rem;margin-bottom:.75rem;cursor:pointer;transition:all .2s}
.clause-option:hover{border-color:var(--accent)}
.clause-option.selected{border-color:var(--accent);background:var(--bg2)}
.clause-option label{display:flex;gap:.75rem;cursor:pointer;align-items:flex-start}
.clause-option input[type="radio"]{margin-top:.35rem;accent-color:var(--accent)}
.clause-option .opt-label{font-weight:600;font-size:.85rem;margin-bottom:.25rem}
.clause-option .opt-content{font-size:.85rem;color:var(--text2);white-space:pre-wrap}
.note-field{margin-top:.5rem}
.note-field textarea{font-size:.85rem}

/* Approval */
.approval-section{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}
.approval-box{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:1.5rem;margin-bottom:1rem}
.approval-status{display:flex;gap:1.5rem;margin-bottom:1.5rem}
.approval-party{flex:1;padding:1rem;border:1px solid var(--border);border-radius:4px;text-align:center}
.approval-party.approved{border-color:var(--green);background:var(--green-bg)}
.approval-party h4{font-size:.85rem;font-weight:600;margin-bottom:.25rem}
.approval-party p{font-size:.8rem;color:var(--text2)}
.confirm-check{display:flex;align-items:flex-start;gap:.75rem;margin:1rem 0}
.confirm-check input[type="checkbox"]{margin-top:.35rem;accent-color:var(--accent)}
.confirm-check label{font-size:.85rem;color:var(--text2)}

/* Share section */
.share-section{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:1.5rem;margin-bottom:2rem}
.share-url{display:flex;gap:.5rem;margin-top:.75rem}
.share-url input{flex:1;padding:.5rem;background:var(--bg);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:.8rem;color:var(--text)}
.share-url .btn{white-space:nowrap}

/* Empty state */
.empty{text-align:center;padding:4rem 2rem;color:var(--text2)}
.empty h2{font-size:1.2rem;margin-bottom:.5rem;color:var(--text)}
.empty p{margin-bottom:1.5rem;font-size:.9rem}

/* Toast */
.toast{position:fixed;bottom:2rem;right:2rem;background:var(--text);color:var(--bg);padding:.75rem 1.5rem;border-radius:6px;font-size:.85rem;transform:translateY(80px);opacity:0;transition:all .3s;z-index:1000}
.toast.show{transform:translateY(0);opacity:1}

/* Gate */
.gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}
.gate-box{text-align:center;max-width:340px;width:100%}
.gate-logo{font-size:2.5rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.15rem}
.gate-phonetic{font-size:.75rem;color:var(--text3);font-family:'Noto Sans',system-ui,sans-serif;font-style:italic;margin-bottom:.5rem}
.gate-tagline{color:var(--accent);font-size:.95rem;font-weight:600;margin-bottom:1.5rem}
.gate-divider{width:2rem;height:1px;background:var(--border);margin:0 auto 1.5rem}
.gate-label{font-size:.8rem;color:var(--text2);margin-bottom:1.25rem;text-transform:uppercase;letter-spacing:.05em}
.gate-form{display:flex;flex-direction:column;gap:.75rem}
.gate-input{width:100%;padding:.7rem 1rem;border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:.9rem;text-align:center;background:var(--bg);color:var(--text);outline:none;transition:border-color .2s}
.gate-input:focus{border-color:var(--accent)}
.gate-error{color:var(--red);font-size:.8rem;margin-top:.75rem}

/* About page */
.about-page h1{font-size:1.8rem;font-weight:700;margin-bottom:.4rem;letter-spacing:-.02em}
.about-hero{text-align:center;margin-bottom:3rem}
.about-tagline{color:var(--accent);font-size:1rem;font-weight:600}
.about-section{margin-bottom:2.5rem}
.about-section h2{font-size:1.1rem;font-weight:600;margin-bottom:.75rem;color:var(--accent)}
.about-section p{color:var(--text2);font-size:.9rem;line-height:1.8;margin-bottom:.75rem}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}
.about-card{border:1px solid var(--border);border-radius:6px;padding:1.25rem}
.about-card h3{font-size:.9rem;font-weight:600;margin-bottom:.3rem}
.about-card p{font-size:.82rem;margin-bottom:0}
.about-pipeline{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}
.about-arrow{color:var(--text3);font-size:1rem}

/* Editor Layout */
.editor-layout{display:grid;grid-template-columns:280px 1fr;max-width:1200px;margin:0 auto;gap:0;min-height:calc(100vh - 120px)}
.editor-main{padding:2rem;overflow-y:auto}

/* Clause Guide Sidebar */
.clause-guide{background:var(--bg2);border-right:1px solid var(--border);padding:1rem;overflow-y:auto;position:sticky;top:49px;height:calc(100vh - 49px);transition:width .2s,padding .2s,opacity .2s}
.clause-guide.collapsed{width:0;padding:0;overflow:hidden;opacity:0;border-right:none}
.guide-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.guide-header h3{font-size:.85rem;font-weight:700;letter-spacing:-.01em}
.guide-hint{font-size:.7rem;color:var(--text3);margin-bottom:.75rem;line-height:1.5}

.guide-tree{font-size:.75rem;line-height:1.3}
.guide-section{margin-bottom:.25rem}
.guide-item{display:flex;align-items:center;gap:.25rem;padding:.2rem .25rem;border-radius:3px;transition:background .15s}
.guide-item:hover{background:var(--bg3)}
.guide-item.guide-added{opacity:.6}
.guide-item.guide-added .guide-label{text-decoration:line-through}
.guide-toggle{background:none;border:none;color:var(--text3);cursor:pointer;font-size:.7rem;padding:0;width:1rem;text-align:center;font-family:inherit;flex-shrink:0}
.guide-toggle.has-children{color:var(--text2)}
.guide-toggle.has-children:hover{color:var(--accent)}
.guide-dot{color:var(--text3);font-size:.7rem;width:1rem;text-align:center;flex-shrink:0}
.guide-id{color:var(--text3);font-size:.65rem;min-width:1.5rem;flex-shrink:0}
.guide-label{color:var(--text2);cursor:pointer;transition:color .15s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.guide-label:hover{color:var(--accent)}
.guide-check{color:var(--green);font-size:.7rem;margin-left:auto;flex-shrink:0}
.guide-children{padding-left:.75rem}

.guide-depth-0>.guide-label{color:var(--text);font-weight:600}
.guide-depth-1>.guide-label{font-weight:500}

/* Dates section */
.dates-section{margin-bottom:1.5rem}
.dates-form{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}
.date-field{display:flex;flex-direction:column;gap:.2rem}
.date-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);font-weight:600}
.date-input{border:1px solid var(--border);padding:.4rem .6rem;border-radius:4px;font-size:.85rem;font-family:inherit;background:var(--bg);color:var(--text)}
.date-input:focus{outline:none;border-color:var(--accent)}

/* Guide type label */
.guide-type{font-size:.7rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem}
.guide-legend{display:inline-flex;align-items:center;gap:.2rem}

/* Clause rename */
.clause-title-group{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}
.clause-title-display{font-size:1rem;font-weight:600;cursor:default}
.clause-rename-btn{font-size:.75rem;color:var(--text3);opacity:0;transition:opacity .15s}
.clause-card:hover .clause-rename-btn{opacity:1}
.clause-rename-form{display:flex;gap:.35rem;align-items:center;flex:1}
.clause-rename-input{border:1px solid var(--border);padding:.3rem .5rem;border-radius:4px;font-size:.85rem;font-family:inherit;background:var(--bg);color:var(--text);flex:1;min-width:0}
.clause-rename-input:focus{outline:none;border-color:var(--accent)}

/* Guide toggle mobile button */
.guide-toggle-mobile{display:none}

/* Responsive */
@media(max-width:768px){
  .features,.steps-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2rem}
  .container{padding:1.5rem}
  .approval-status{flex-direction:column}
  .nav-inner{padding:.75rem 1rem}
  .dash-toolbar{flex-direction:column}
  .dash-create{width:100%;flex-wrap:wrap}
  .dash-input{width:100%;min-width:0}
  .dash-filter-bar{flex-wrap:wrap}
  .dash-filter-bar .dash-select,.dash-filter-bar .dash-input{flex:1;min-width:0}
  .dash-table-head{display:none}
  .dash-table-row{grid-template-columns:auto 1fr;gap:.15rem .4rem;padding:.75rem}
  .dash-table-row .col-status{grid-column:1}
  .dash-table-row .col-eff{grid-column:2;align-self:center}
  .dash-table-row .col-eff .health-dot{font-size:.85rem}
  .dash-table-row .col-date,.dash-table-row .col-name,.dash-table-row .col-cat,.dash-table-row .col-party,.dash-table-row .col-ref,.dash-table-row .col-actions{grid-column:1/-1}
  .dash-table-row .col-ref{font-size:.7rem}
  .dash-table-row .col-actions{display:flex;justify-content:flex-end}
  .nav-profile{max-width:100px}
  .dash-wip-grid{grid-template-columns:1fr}
  .landing-features-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .preview-row{grid-template-columns:5rem 1.5rem 4.5rem 1.5fr 1fr;font-size:.7rem}
  .callout-inner{grid-template-columns:1fr}
  .how-pipeline{gap:.3rem}
  .editor-layout{grid-template-columns:1fr}
  .clause-guide{position:fixed;left:0;top:49px;width:280px;height:calc(100vh - 49px);z-index:50;transform:translateX(-100%);transition:transform .25s;border-right:1px solid var(--border)}
  .clause-guide.collapsed{transform:translateX(-100%)}
  .clause-guide:not(.collapsed){transform:translateX(0)}
  .guide-toggle-mobile{display:inline-flex}
}

@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .share-url{flex-direction:column}
}

@media print{
  .nav,.footer,.btn,.clause-actions,.share-section,.approval-section{display:none!important}
  body{background:#fff;color:#111}
  .card{border:none;box-shadow:none}
}
