    :root{
      --bg:#f6f5f2;
      --paper:#fff;
      --ink:#171717;
      --muted:#6f6f6f;
      --line:#dedbd4;
      --soft:#efede8;
      --brand:#8b0f12;
      --brand2:#5d0c0f;
      --black:#161616;
      --green:#57e5a0;
      --shadow:0 22px 80px rgba(0,0,0,.10);
      --radius:22px;
      --font-ar: "Tahoma", "Arial", sans-serif;
      --font-en: "Inter", "Segoe UI", Arial, sans-serif;
    }
    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{margin:0;background:radial-gradient(circle at top left, rgba(139,15,18,.08), transparent 32%),var(--bg);color:var(--ink);font-family:var(--font-ar);line-height:1.9}
    body.lock{overflow:hidden}
    a{color:inherit;text-decoration:none}
    .topbar{position:sticky;top:0;z-index:40;background:rgba(246,245,242,.88);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.08)}
    .topbar-inner{max-width:1220px;margin:auto;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 22px}
    .brandlock{display:flex;align-items:center;gap:12px;direction:ltr}
    .brandlock img.apex{height:38px;width:auto;object-fit:contain}
    .brandlock .divider{width:1px;height:32px;background:#cfcac1}
    .brandlock .client-box{height:42px;width:115px;background:#000;border-radius:10px;display:grid;place-items:center;padding:8px 12px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
    .brandlock .client-box img{width:100%;height:100%;object-fit:contain}
    .nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-start}
    .nav a,.btn{border:1px solid #d9d5cc;background:#fff;border-radius:999px;padding:9px 13px;font-size:13px;line-height:1.2;cursor:pointer;transition:.2s ease;font-family:var(--font-ar);display:inline-flex;align-items:center;gap:8px}
    .nav a:hover,.btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
    .btn.dark{background:var(--black);color:#fff;border-color:var(--black)}
    .btn.red{background:var(--brand);color:#fff;border-color:var(--brand)}
    .btn.ghost{background:transparent}
    .progress{position:absolute;bottom:-1px;right:0;height:3px;background:var(--brand);width:0;transition:width .1s linear}
    .wrap{max-width:1220px;margin:auto;padding:32px 22px 70px}
    .hero{background:linear-gradient(135deg,#fff 0,#fff 50%,#f1eee8 100%);border:1px solid var(--line);border-radius:32px;padding:44px 42px;box-shadow:var(--shadow);position:relative;overflow:hidden}
    .hero:before{content:"";position:absolute;inset:auto -90px -160px auto;width:360px;height:360px;border:1px solid rgba(139,15,18,.18);border-radius:50%}
    .hero:after{content:"AE";position:absolute;left:38px;bottom:10px;font-family:var(--font-en);font-weight:900;font-size:128px;letter-spacing:-10px;color:rgba(0,0,0,.035);direction:ltr}
    .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center;position:relative;z-index:1}
    .eyebrow{color:var(--brand);font-weight:800;letter-spacing:.3px;font-size:14px;margin-bottom:8px}
    h1{margin:0;font-size:clamp(32px,4.6vw,62px);line-height:1.2;letter-spacing:-1px;color:#111}
    .hero .subtitle{font-size:19px;color:#4b4b4b;margin:16px 0 0;max-width:760px}
    .hero-card{background:#151515;color:#fff;border-radius:24px;padding:26px;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px rgba(0,0,0,.18)}
    .hero-card .client-logo{height:96px;background:#000;border-radius:18px;display:grid;place-items:center;padding:20px;margin-bottom:18px;border:1px solid rgba(255,255,255,.08)}
    .hero-card .client-logo img{max-width:88%;max-height:72px;object-fit:contain}
    .stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
    .stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:14px}
    .stat span{display:block;color:#bdbdbd;font-size:12px;margin-bottom:4px}
    .stat strong{display:block;font-size:18px;color:#fff;line-height:1.4}
    section{margin-top:28px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:0 12px 40px rgba(0,0,0,.05)}
    .section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;border-bottom:2px solid var(--brand);padding-bottom:13px;margin-bottom:20px}
    h2{margin:0;color:var(--brand);font-size:25px;line-height:1.35}
    .section-head p{margin:0;color:var(--muted);font-size:14px;max-width:620px}
    h3{margin:22px 0 10px;font-size:20px;color:#191919}
    p{margin:0 0 12px}
    .lead{font-size:18px;color:#333;max-width:1080px}
    .grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}
    .info-card{border:1px solid var(--line);background:#fbfaf8;border-radius:18px;padding:18px}
    .info-card strong{display:block;margin-bottom:8px;font-size:17px}.info-card small{color:var(--muted);font-size:13px}
    .chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
    .chip{background:#f2eeee;border:1px solid #e1d6d6;color:#5b1113;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}
    table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
    thead th{background:#151515;color:#fff;padding:14px 12px;font-weight:700;text-align:right;border-left:1px solid rgba(255,255,255,.09);font-size:14px}
    tbody td{padding:14px 12px;border-top:1px solid var(--line);border-left:1px solid var(--line);vertical-align:top;font-size:14px}
    tbody tr:nth-child(even) td{background:#fcfbfa}.price{font-family:var(--font-en);direction:ltr;white-space:nowrap;font-weight:800}.muted{color:var(--muted)}
    .module-name{font-weight:800;font-size:15px;color:#151515}.module-desc{color:#545454;font-size:13px;line-height:1.7}.features-list{margin:8px 0 0;padding:0;list-style:none}.features-list li{position:relative;padding-right:16px;margin:3px 0;color:#3f3f3f}.features-list li:before{content:"";position:absolute;right:0;top:.82em;width:6px;height:6px;border-radius:50%;background:var(--brand)}
    .financial-box{border:2px solid var(--brand);border-radius:20px;padding:24px;text-align:center;background:linear-gradient(180deg,#fff,#fbf6f6)}
    .financial-box .big{font-size:42px;font-family:var(--font-en);font-weight:900;color:var(--brand);direction:ltr;line-height:1.2}.financial-box .words{font-size:20px;margin-top:8px;color:#333}
    .payments{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.pay-card{border:1px solid var(--line);border-radius:18px;padding:18px;background:#fbfaf8;text-align:center}.pay-card .pct{font-size:28px;font-family:var(--font-en);font-weight:900;color:var(--brand)}.pay-card .amount{font-family:var(--font-en);font-weight:900;font-size:22px;direction:ltr;margin:6px 0}
    .note{background:#fff8e9;border:1px solid #ead7a7;border-radius:16px;padding:15px;color:#624500}.confidential{text-align:center;color:var(--muted);font-size:13px;margin-top:22px}
    .signatures{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}.sig{border:1px solid var(--line);border-radius:18px;padding:18px;background:#fbfaf8;min-height:150px}.line{border-bottom:1px solid #bdb8b0;height:36px;margin-top:6px}
    .sig-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.sig-title strong{font-size:16px}.sig-title small{color:var(--muted);font-size:12px}.sig-canvas-wrap{background:#fff;border:1px dashed #c9c3ba;border-radius:16px;padding:10px;position:relative}.signature-canvas{width:100%;height:150px;display:block;background:#fff;border-radius:12px;touch-action:none;cursor:crosshair}.sig-hint{position:absolute;inset:0;display:grid;place-items:center;color:#aaa;font-size:13px;pointer-events:none}.sig.has-signature .sig-hint{display:none}.sig-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.sig-actions .btn{font-size:12px;padding:8px 10px}.sig-date-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;align-items:end}.sig-date-row label{font-size:12px;color:var(--muted);font-weight:800}.sig-date-row input{width:100%;border:1px solid #d8d3ca;border-radius:12px;padding:9px 10px;background:#fff;font-family:var(--font-ar)}.sig-name-line{border-bottom:1px solid #bdb8b0;min-height:32px;padding-top:8px;color:#777}.sig-upload{display:none}
    .drawer{position:fixed;inset:0;z-index:100;display:none}.drawer.open{display:block}.drawer-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(3px)}.drawer-panel{position:absolute;top:0;bottom:0;left:0;width:min(980px,96vw);background:#f8f7f3;box-shadow:-20px 0 80px rgba(0,0,0,.25);overflow:auto;padding:22px;direction:rtl}.drawer-head{display:flex;justify-content:space-between;align-items:center;gap:12px;position:sticky;top:0;background:#f8f7f3;z-index:4;padding-bottom:14px;border-bottom:1px solid var(--line)}.drawer-head h2{color:#111}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0}.tab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 12px;cursor:pointer}.tab.active{background:#151515;color:#fff}.panel{display:none}.panel.active{display:block}
    .form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;color:#6a6a6a;font-weight:700}.field input,.field textarea,.field select{border:1px solid #d8d3ca;border-radius:13px;padding:10px 12px;font-family:var(--font-ar);font-size:14px;background:#fff;color:#111}.field textarea{min-height:78px;resize:vertical}.toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-weight:700}.toggle input{width:18px;height:18px;accent-color:var(--brand)}
    .admin-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;margin-bottom:12px}.admin-card.disabled{opacity:.55;background:#f3f0ea}.admin-card-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}.admin-actions{display:flex;gap:8px;flex-wrap:wrap}.mini{font-size:12px;padding:7px 9px}.feature-row,.resource-row{display:grid;grid-template-columns:38px 1fr 90px 120px 90px;gap:8px;align-items:center;margin:8px 0}.feature-head{display:grid;grid-template-columns:38px 1fr 90px 120px 90px;gap:8px;margin-top:10px;color:#777;font-size:12px;font-weight:800}.resource-row{grid-template-columns:1.15fr 120px 90px 90px 110px 48px}.feature-row input,.resource-row input{border:1px solid #d8d3ca;border-radius:10px;padding:8px;background:#fff}.feature-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--brand)}.calc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.calc{background:#151515;color:#fff;border-radius:18px;padding:16px}.calc span{display:block;color:#aaa;font-size:12px}.calc strong{font-family:var(--font-en);font-size:22px;direction:ltr;display:block;line-height:1.4}.calc.good strong{color:var(--green)}.calc.warn strong{color:#ffd166}.hidden{display:none!important}
    .toast{position:fixed;bottom:20px;right:20px;background:#151515;color:#fff;border-radius:999px;padding:12px 16px;box-shadow:0 16px 40px rgba(0,0,0,.25);opacity:0;transform:translateY(16px);transition:.25s;z-index:200}.toast.show{opacity:1;transform:translateY(0)}

    .onboarding{position:fixed;inset:0;z-index:1000;background:radial-gradient(circle at 12% 10%,rgba(139,15,18,.18),transparent 28%),linear-gradient(135deg,#f6f5f2 0%,#fff 45%,#ebe7df 100%);display:grid;place-items:center;padding:28px}
    body:not(.onboard-active) .onboarding{display:none}.onboard-active .topbar,.onboard-active main,.onboard-active .drawer{display:none!important}.onboarding-card{width:min(1060px,100%);background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border:1px solid rgba(222,219,212,.9);box-shadow:var(--shadow);border-radius:34px;overflow:hidden}.onboarding-top{display:grid;grid-template-columns:1.2fr .8fr;min-height:520px}.onboarding-copy{padding:46px}.onboarding-copy .brandlock{margin-bottom:28px}.onboarding-copy h1{font-size:44px;line-height:1.25;margin:0 0 16px}.onboarding-copy p{color:#4f4f4f;font-size:16px;margin:0 0 22px}.access-panel{background:#151515;color:#fff;padding:46px;display:flex;flex-direction:column;justify-content:center}.access-panel h2{margin:0 0 8px;font-size:28px}.access-panel p{color:#c9c9c9;margin:0 0 18px}.access-input{width:100%;padding:16px;border-radius:16px;border:1px solid #333;background:#fff;color:#111;font-size:22px;letter-spacing:4px;text-align:center;font-family:var(--font-en);font-weight:800}.access-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.access-error{min-height:24px;color:#ffb3b3;font-size:13px;margin-top:10px}.access-note{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:12px;margin-top:18px;color:#ddd;font-size:13px}.mode-badge{border:1px solid var(--line);border-radius:999px;padding:8px 12px;background:#fff;font-weight:900;color:#333;font-size:12px}.client-only{display:none!important}body.mode-client .client-only{display:block!important}body.mode-client .client-only.grid{display:grid!important}body.mode-client #openAdmin,body.mode-client .admin-only{display:none!important}.client-workbench{background:#151515;color:#fff;border-radius:26px;padding:22px;box-shadow:var(--shadow);margin-top:16px}.client-workbench .section-head h2,.client-workbench .section-head p{color:#fff}.client-workbench .muted{color:#cfcfcf}.client-tools{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;align-items:start}.client-tool-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:16px}.client-tool-card label{display:block;font-weight:900;margin-bottom:8px}.client-tool-card input{width:100%;border:0;border-radius:14px;padding:12px;font-size:18px;font-family:var(--font-en);font-weight:900;text-align:center}.client-message{margin-top:10px;min-height:24px;color:#ffd166;font-weight:800}.client-togglebox{margin-top:10px;border:1px solid #e0dcd3;background:#fbfaf8;border-radius:14px;padding:10px}.client-togglebox label,.client-feature-toggle{display:flex;align-items:center;gap:8px;font-weight:900;color:#333}.client-togglebox input,.client-feature-toggle input{width:18px;height:18px;accent-color:var(--brand)}.client-feature-toggle{margin:4px 0 3px 0;font-size:12px}.client-disabled{opacity:.55;text-decoration:line-through}.client-mode-hint{font-size:12px;color:#8b0f12;font-weight:900;margin-top:6px}.role-chip{display:inline-flex;align-items:center;gap:8px;background:#8b0f12;color:#fff;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:900}



    /* Enhanced onboarding and notification layer */
    .onboarding{background:#0f0f0f;overflow:auto;place-items:start center;padding:34px 24px;background:
      radial-gradient(circle at 18% 12%, rgba(255,255,255,.12), transparent 26%),
      radial-gradient(circle at 88% 86%, rgba(139,15,18,.18), transparent 30%),
      linear-gradient(135deg,#0e0e0e 0%,#191919 58%,#090909 100%)}
    .onboarding-card{width:min(1180px,100%);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);box-shadow:0 34px 110px rgba(0,0,0,.38);border-radius:38px;overflow:hidden;position:relative}
    .onboarding-card:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.07),transparent 42%,rgba(139,15,18,.08));pointer-events:none}
    .onboarding-top{grid-template-columns:1.25fr .75fr;min-height:620px;position:relative;z-index:1}
    .onboarding-copy{padding:54px;color:#fff;display:flex;flex-direction:column;justify-content:space-between;gap:30px}
    .onboarding-copy .brandlock{margin-bottom:10px;background:#fff;border:1px solid rgba(255,255,255,.10);border-radius:22px;padding:14px 16px;width:max-content;max-width:100%}
    .onboarding-copy .brandlock .divider{background:rgba(255,255,255,.22)}
    .onboarding-copy h1{font-size:clamp(38px,5vw,70px);line-height:1.14;margin:0 0 18px;color:#fff;letter-spacing:-.8px}
    .onboarding-copy h1 span{color:#d8d2c7!important}
    .onboarding-copy p{color:#d7d7d7;font-size:18px;line-height:2;max-width:760px;margin:0}
    .role-chip{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);color:#fff;margin-bottom:16px;width:max-content;letter-spacing:.4px}
    .project-pillars{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:24px}
    .pillar{background:rgba(255,255,255,.065);border:1px solid rgba(255,255,255,.11);border-radius:18px;padding:16px;color:#fff}
    .pillar strong{display:block;font-size:16px;margin-bottom:8px}.pillar small{color:#c6c6c6;font-size:12px;line-height:1.7}
    .project-route{display:flex;gap:8px;flex-wrap:wrap;margin-top:24px}.route-step{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);border-radius:999px;color:#e8e8e8;padding:8px 12px;font-size:12px;font-weight:800}
    .access-panel{background:linear-gradient(180deg,#ffffff 0%,#f4f1ea 100%);color:#141414;padding:46px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid rgba(255,255,255,.08)}
    .access-panel h2{margin:0 0 8px;font-size:30px;color:#111}.access-panel p{color:#555;margin:0 0 22px}
    .access-input{border:1px solid #d7d2c7;background:#fff;color:#111;box-shadow:0 12px 34px rgba(0,0,0,.08)}
    .access-error{color:#8b0f12;font-weight:800}.access-note{background:#fff;border:1px solid #e2ded5;color:#5e5e5e}
    .access-actions .btn.dark{justify-content:center}.access-actions .btn{justify-content:center}
    .bell-wrap{position:relative;display:inline-flex}.bell-btn{position:relative}.notif-count{position:absolute;top:-7px;left:-7px;min-width:19px;height:19px;border-radius:999px;background:#8b0f12;color:#fff;display:none;place-items:center;font-size:11px;font-family:var(--font-en);font-weight:900;border:2px solid #fff}.notif-count.show{display:grid}.notif-panel{position:absolute;top:44px;left:0;width:min(390px,92vw);max-height:440px;overflow:auto;background:#fff;border:1px solid var(--line);box-shadow:0 24px 70px rgba(0,0,0,.18);border-radius:18px;padding:12px;display:none;z-index:80}.notif-panel.open{display:block}.notif-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:4px 4px 10px;border-bottom:1px solid var(--line);margin-bottom:8px}.notif-head strong{font-size:15px}.notif-item{border:1px solid #e7e2da;border-radius:14px;background:#fbfaf8;padding:11px;margin:8px 0}.notif-item.unread{border-color:#c7b18a;background:#fff8e9}.notif-item strong{display:block;font-size:13px;margin-bottom:5px}.notif-item p{font-size:12px;line-height:1.6;margin:0;color:#555}.notif-time{font-size:11px;color:#888;margin-top:6px;direction:ltr;text-align:left}.notif-empty{text-align:center;color:#777;padding:20px 8px}.discount-status{display:inline-flex;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;background:#eee;color:#333}.discount-status.pending{background:#fff4d2;color:#725200}.discount-status.approved{background:#dcfce7;color:#166534}.discount-status.negotiated{background:#e0f2fe;color:#075985}.discount-status.rejected{background:#fee2e2;color:#991b1b}.discount-request-card{border:1px solid var(--line);border-radius:16px;background:#fff;padding:14px;margin:10px 0}.discount-request-card .row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:10px 0}.discount-request-card .row div{background:#fbfaf8;border:1px solid #eee;border-radius:12px;padding:10px}.discount-request-card small{display:block;color:#777}.client-tool-card .fieldish{margin-top:10px}.client-tool-card .fieldish label{font-size:12px;color:#ddd}.client-tool-card .fieldish input{margin-top:6px;font-size:14px;text-align:right;font-family:var(--font-ar);letter-spacing:0}

    .bell-icon{width:20px;height:20px;display:block;fill:currentColor}.bell-btn{width:42px;height:42px;padding:0!important;justify-content:center;border-radius:999px}.approval-cta{margin-top:18px;border:1px solid #dedbd4;background:#151515;color:#fff;border-radius:22px;padding:20px;display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center}.approval-cta h3{color:#fff;margin:0 0 6px}.approval-cta p{color:#d7d7d7;margin:0}.approval-cta .btn{white-space:nowrap}.approval-message{grid-column:1/-1;color:#ffd166;font-weight:800;min-height:24px}.approval-cta input{border:0;border-radius:14px;padding:11px 12px;min-width:240px;font-family:var(--font-ar)}
    @media(max-width:900px){.project-pillars{grid-template-columns:1fr}.notif-panel{right:auto;left:0}.discount-request-card .row{grid-template-columns:1fr 1fr}.approval-cta{grid-template-columns:1fr}.approval-cta input{width:100%;min-width:0}}

    @media(max-width:900px){.hero-grid,.grid.two,.grid.three,.grid.four,.payments,.signatures,.form-grid,.calc-grid,.onboarding-top,.client-tools{grid-template-columns:1fr}.topbar-inner{align-items:flex-start;flex-direction:column}.hero{padding:26px 20px}.feature-row,.feature-head{grid-template-columns:34px 1fr 1fr}.feature-row button{grid-column:span 1}.resource-row{grid-template-columns:1fr 1fr}.drawer-panel{width:100%}}
    @media print{body{background:#fff}.topbar,.drawer,.toast,.no-print,.sig-actions,.sig-upload{display:none!important}.wrap{max-width:none;padding:0}.hero,section{box-shadow:none;border-radius:0;border:0;border-bottom:1px solid #ddd;break-inside:avoid}.hero{padding:20px}.hero-grid{grid-template-columns:1fr}.hero-card{background:#151515!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}thead th{background:#151515!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}h1{font-size:34px}.financial-box{break-inside:avoid}.section-head{break-after:avoid}table{break-inside:auto}tr{break-inside:avoid}.confidential{position:fixed;bottom:10px;left:0;right:0}}

    /* Post-approval stage: contract and Statement of Work preparation. */
    .contract-preparation[hidden]{display:none!important}
    .contract-preparation{position:relative;isolation:isolate;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:28px;margin-top:28px;padding:34px;border:1px solid rgba(255,255,255,.14);border-radius:30px;background:linear-gradient(135deg,#111 0%,#201314 53%,#5d0c0f 140%);box-shadow:0 26px 68px rgba(46,7,9,.28);color:#fff}
    .contract-preparation:before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(116deg,rgba(255,255,255,.075),transparent 38%,rgba(255,255,255,.03));pointer-events:none}
    .contract-preparation__orb{position:absolute;z-index:-1;border-radius:50%;filter:blur(1px);pointer-events:none}.contract-preparation__orb--one{width:350px;height:350px;left:-180px;bottom:-230px;background:radial-gradient(circle,rgba(255,255,255,.14),transparent 67%)}.contract-preparation__orb--two{width:420px;height:420px;right:-230px;top:-250px;border:1px solid rgba(255,255,255,.12)}
    .contract-preparation__eyebrow{display:flex;align-items:center;gap:9px;color:#f4ddbd;font-size:13px;font-weight:900;letter-spacing:.2px}.approval-check{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#59dda1;color:#0f281c;font-family:Arial,sans-serif;font-size:15px;font-weight:900}.contract-preparation h2{margin:14px 0 10px;color:#fff;font-size:clamp(27px,3.3vw,42px);line-height:1.3}.contract-preparation__content>p{max-width:690px;color:#e0d9d2;font-size:16px;line-height:1.95;margin:0}
    .contract-steps{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:9px;margin-top:24px}.contract-step{display:flex;align-items:center;gap:9px;min-height:64px;padding:10px;border:1px solid rgba(255,255,255,.12);border-radius:15px;background:rgba(255,255,255,.055);color:#c7c2bd}.contract-step>span{display:grid;flex:0 0 28px;place-items:center;width:28px;height:28px;border:1px solid rgba(255,255,255,.25);border-radius:50%;font-family:var(--font-en);font-size:12px;font-weight:900}.contract-step strong,.contract-step small{display:block}.contract-step strong{font-size:13px;color:inherit}.contract-step small{margin-top:2px;font-size:11px;color:inherit}.contract-step.complete{color:#ccf5dc;background:rgba(87,229,160,.12);border-color:rgba(87,229,160,.28)}.contract-step.complete>span{background:#57e5a0;border-color:#57e5a0;color:#13271e}.contract-step.active{color:#fff5e8;border-color:#e2bd8b;background:linear-gradient(135deg,rgba(226,189,139,.23),rgba(255,255,255,.08));box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}.contract-step.active>span{background:#f1c78f;border-color:#f1c78f;color:#3a2110}
    .contract-preparation__aside{align-self:stretch;display:flex;flex-direction:column;justify-content:center;padding:24px;border:1px solid rgba(255,255,255,.13);border-radius:21px;background:rgba(255,255,255,.075);backdrop-filter:blur(10px)}.stage-status{display:flex;align-items:center;gap:8px;color:#f5d6b3;font-size:12px;font-weight:900}.stage-status__pulse{display:block;width:8px;height:8px;border-radius:50%;background:#f3bd78;box-shadow:0 0 0 0 rgba(243,189,120,.65);animation:stage-pulse 1.7s infinite}.contract-preparation__aside>strong{margin-top:12px;font-size:26px;line-height:1.25}.contract-preparation__aside>p{margin:10px 0 18px;color:#ded9d4;font-size:13px;line-height:1.8}.contract-preparation__actions{display:flex;flex-wrap:wrap;gap:8px}.contract-preparation__actions .btn{justify-content:center;font-size:12px}.contract-preparation__actions .btn.dark{background:#fff;color:#171717;border-color:#fff}
    .approval-card{overflow:hidden;border:1px solid #dedbd4;border-radius:20px;background:#fff;margin:12px 0;box-shadow:0 12px 32px rgba(0,0,0,.06)}.approval-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 17px;border-bottom:1px solid #e8e4dd;background:linear-gradient(135deg,#fbfaf8,#f5f0e8)}.approval-card__head h3{margin:5px 0 0;font-size:18px}.approval-card__badge{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;background:#daf5e5;color:#17603b;font-size:11px;font-weight:900}.approval-card__badge:before{content:"✓";display:grid;place-items:center;width:14px;height:14px;border-radius:50%;background:#1c8a50;color:#fff;font-size:10px}.approval-card__body{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:16px;padding:17px}.approval-details{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.approval-detail{padding:10px 11px;border:1px solid #ede9e2;border-radius:12px;background:#fbfaf8}.approval-detail small{display:block;margin-bottom:3px;color:#777;font-size:11px}.approval-detail strong{font-size:13px;overflow-wrap:anywhere}.approval-signature{margin:0;padding:10px;border:1px dashed #bcb4a8;border-radius:14px;background:#fff;text-align:center}.approval-signature figcaption{margin-top:7px;color:#74706a;font-size:11px;font-weight:800}.approval-signature img{display:block;width:100%;height:104px;object-fit:contain;background:#fff}.approval-signature--missing{display:grid;min-height:138px;place-items:center;color:#8a8279;font-size:12px}.approval-stage{margin:0 17px 17px;padding:10px 12px;border-radius:12px;background:#171717;color:#fff;font-size:12px;font-weight:800}.approval-stage span{color:#f2c78c}
    body.mode-client.quotation-approved #clientControls,body.mode-client.quotation-approved .approval-cta{display:none!important}body.mode-client.quotation-approved [data-signature-box="client"] .sig-actions{display:none!important}body.mode-client.quotation-approved #signatureDateClient{pointer-events:none;background:#f1efeb;color:#777}body.mode-client.quotation-approved #signatureCanvasClient{pointer-events:none;cursor:default}
    @keyframes stage-pulse{70%{box-shadow:0 0 0 8px rgba(243,189,120,0)}100%{box-shadow:0 0 0 0 rgba(243,189,120,0)}}
    @media(max-width:900px){.contract-preparation{grid-template-columns:1fr;padding:24px}.contract-steps{grid-template-columns:1fr}.approval-card__body{grid-template-columns:1fr}.approval-signature{max-width:320px}.approval-details{grid-template-columns:1fr}.contract-preparation__aside{padding:19px}}

    /* The client sees the contract/SOW handoff as a dedicated full-page stage. */
    .approved-offer-only{display:none!important}
    body.mode-client.quotation-approved:not(.viewing-approved-offer){overflow:hidden}
    body.mode-client.quotation-approved .contract-preparation:not([hidden]){position:fixed;inset:0;z-index:900;width:auto;min-height:100dvh;max-height:100dvh;align-content:center;overflow-y:auto;margin:0;padding:clamp(28px,6vw,88px);border:0;border-radius:0}
    body.mode-client.quotation-approved.viewing-approved-offer .approved-offer-only{display:inline-flex!important}
    @media(max-width:900px){body.mode-client.quotation-approved .contract-preparation:not([hidden]){min-height:100dvh;max-height:100dvh;padding:28px 20px;align-content:start}}

    /* Signed-signature display inside the offer (shared between client and admin). */
    .sig-canvas-wrap .sig-signed{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;background:#fff;border-radius:16px;padding:10px;text-align:center}
    .sig-signed[hidden]{display:none!important}
    .sig-signed__img{max-height:104px;max-width:92%;object-fit:contain}
    .sig-signed__meta{display:flex;flex-direction:column;gap:2px}
    .sig-signed__label{font-size:12px;font-weight:800;color:#17603b}
    .sig-signed__date{font-size:11px;color:#6f6f6f}
    .sig-signed--waiting{background:repeating-linear-gradient(45deg,#fbfaf8,#fbfaf8 10px,#f4f1ec 10px,#f4f1ec 20px)}
    .sig-signed--waiting .sig-signed__img{display:none}
    .sig-signed--waiting .sig-signed__label{color:#8a7a52}
    .sig.is-signed .sig-canvas-wrap{border-style:solid;border-color:#bcd9c6}
    .apex-sign-cta{margin-top:12px;border:1px solid #d8d3ca;background:#fff;border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:8px}
    .apex-sign-cta[hidden]{display:none!important}
    .apex-sign-cta .btn{justify-content:center}
    .apex-sign-message{font-size:12px;font-weight:800;color:#8a5c18;min-height:18px}
    .approval-signatures{display:grid;gap:10px;align-content:start}
    .contract-signoffs{display:grid;gap:8px;margin:14px 0 4px}
    .contract-signoffs .signoff{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 11px;border:1px solid rgba(255,255,255,.16);border-radius:12px;background:rgba(255,255,255,.06)}
    .contract-signoffs .signoff span{font-size:12px;color:#e0d9d2;font-weight:800}
    .contract-signoffs .signoff strong{font-size:12px;font-family:var(--font-en);direction:ltr}
    .contract-signoffs .signoff strong.ok{color:#7ce8b0}
    .contract-signoffs .signoff strong.wait{color:#f3bd78}
    @media print{.apex-sign-cta{display:none!important}}

    /* ===== المرحلة الثانية: العقد / SOW ===== */
    .sow-admin-status{margin-bottom:12px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fbfaf8;font-weight:800;font-size:13px}
    .sow-admin-status strong{color:var(--brand)}
    .sow-cr{border:1px solid #e7e2da;border-radius:14px;background:#fff;padding:12px;margin:10px 0}
    .sow-cr__head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:6px}
    #sowAdminBody textarea{min-height:120px}
    .sow-document[hidden]{display:none!important}
    .sow-document{margin-top:28px}
    body.mode-client.sow-active{overflow:hidden}
    body.mode-client #sowDocument:not([hidden]){position:fixed;inset:0;z-index:900;overflow-y:auto;margin:0;padding:clamp(16px,3vw,40px);background:radial-gradient(circle at 12% 8%,rgba(139,15,18,.12),transparent 30%),linear-gradient(135deg,#0e0e0e 0%,#191919 60%,#090909 100%)}
    #sowDocumentBody{max-width:1120px;margin:0 auto;color:#1c1c1c}
    .sow-hero{margin-top:0}
    .sow-hero__brand{margin-bottom:18px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px 14px;width:max-content;max-width:100%}
    .sow-doc__meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
    .sow-doc__metaitem{border:1px solid var(--line);border-radius:12px;background:#fbfaf8;padding:9px 11px}
    .sow-doc__metaitem small{display:block;color:#777;font-size:11px;margin-bottom:3px}
    .sow-doc__metaitem strong{font-size:13px;overflow-wrap:anywhere}
    .sow-doc__section{margin-top:20px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:0 12px 40px rgba(0,0,0,.05)}
    .sow-doc__section>h2{color:var(--brand);font-size:22px;border-bottom:2px solid var(--brand);padding-bottom:11px;margin:0 0 16px}
    .sow-clause{padding:14px 0;border-bottom:1px solid var(--line)}
    .sow-clause:last-child{border-bottom:0;padding-bottom:0}
    .sow-clause__head h3{margin:0;color:#151515;font-size:17px;flex:1;min-width:200px}
    .sow-doc__section p{margin:0 0 8px;line-height:1.95;color:#2b2b2b}
    .sow-doc__section ul{margin:0;padding-right:18px}.sow-doc__section li{margin:5px 0;line-height:1.9;color:#2b2b2b}
    .sow-doc__finbox{border:2px solid var(--brand);border-radius:16px;text-align:center;padding:16px;background:linear-gradient(180deg,#fff,#fbf6f6);margin-bottom:12px}
    .sow-doc__finbox strong{display:block;font-family:var(--font-en);font-weight:900;font-size:30px;color:var(--brand);direction:ltr}
    .sow-doc__finbox span{color:#444}
    .sow-pays{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
    .sow-pay{border:1px solid var(--line);border-radius:14px;background:#fbfaf8;padding:14px;text-align:center}
    .sow-pay .pct{font-family:var(--font-en);font-weight:900;font-size:24px;color:var(--brand)}
    .sow-pay .amount{font-family:var(--font-en);font-weight:900;direction:ltr;margin:4px 0}
    .sow-pay p{font-size:12px;color:#666;margin:6px 0 0}
    .sow-clause__head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}
    .sow-clause__req{white-space:nowrap}
    .sow-clause__badge{font-size:11px;font-weight:900;border-radius:999px;padding:4px 9px}
    .sow-clause__badge.pending{background:#fff4d2;color:#725200}.sow-clause__badge.responded{background:#e0f2fe;color:#075985}
    .sow-clause__cr{margin-top:10px;border:1px dashed #c9b78f;background:#fffdf6;border-radius:12px;padding:11px}
    .sow-clause__cr p{font-size:13px;margin:0 0 5px}
    .sow-doc__sigs{display:grid;grid-template-columns:1fr 1fr;gap:16px}
    .sow-sig{margin:0;border:1px dashed #bcb4a8;border-radius:14px;background:#fff;padding:12px;text-align:center}
    .sow-sig img{display:block;width:100%;height:96px;object-fit:contain}
    .sow-sig.empty{display:grid;min-height:120px;place-items:center;color:#8a8279;font-size:12px}
    .sow-sig figcaption{margin-top:8px;color:#74706a;font-size:12px;font-weight:800}
    .sow-doc__actions{margin-top:22px;border-top:1px solid var(--line);padding-top:16px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
    .sow-doc__hint{flex:1;min-width:220px;color:#8a5c18;font-weight:800;font-size:13px}
    @media(max-width:900px){.sow-doc__meta{grid-template-columns:1fr 1fr}.sow-pays{grid-template-columns:1fr}.sow-doc__sigs{grid-template-columns:1fr}}
    @media print{body.sow-active .topbar,body.sow-active #contractPreparation{display:none!important}body.sow-active #sowDocument:not([hidden]){position:static!important;padding:0;background:#fff}body.sow-active #sowDocumentBody{box-shadow:none;max-width:none;padding:0}.sow-doc__actions{display:none!important}}

    .btn.is-loading{cursor:wait;opacity:.82;transform:none!important;box-shadow:none!important}.btn.is-loading:disabled{cursor:wait}.btn-spinner{width:14px;height:14px;border:2px solid currentColor;border-left-color:transparent;border-radius:50%;animation:btn-spin .7s linear infinite}.client-message{transition:color .2s ease}
    @keyframes btn-spin{to{transform:rotate(360deg)}}

    .discount-status-banner[hidden]{display:none!important}.discount-status-banner{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.9fr);gap:22px;align-items:center;position:relative;overflow:hidden;margin-top:28px;padding:24px 26px;border:1px solid #d9dce8;border-radius:24px;background:linear-gradient(135deg,#fbfcff,#f0f4fb);box-shadow:0 14px 38px rgba(21,37,67,.07)}.discount-status-banner:after{content:"";position:absolute;width:230px;height:230px;left:-110px;bottom:-150px;border:1px solid currentColor;border-radius:50%;opacity:.13;pointer-events:none}.discount-banner__eyebrow{display:flex;align-items:center;gap:8px;color:#335a91;font-size:12px;font-weight:900}.discount-banner__dot{width:9px;height:9px;border-radius:50%;background:currentColor;box-shadow:0 0 0 5px rgba(51,90,145,.1)}.discount-banner__intro h2{margin:8px 0 5px;color:#17233a;font-size:24px}.discount-banner__intro p{margin:0;max-width:700px;color:#59657a;font-size:14px;line-height:1.8}.discount-banner__values{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;position:relative;z-index:1}.discount-banner__value{min-height:80px;padding:12px;border:1px solid #dfe4ef;border-radius:15px;background:rgba(255,255,255,.78)}.discount-banner__value small{display:block;margin-bottom:5px;color:#70798a;font-size:11px;font-weight:800}.discount-banner__value strong{display:block;color:#17233a;font-family:var(--font-en);font-size:14px;line-height:1.45;direction:ltr;overflow-wrap:anywhere}.discount-status-banner.status-negotiated{border-color:#d8c29b;background:linear-gradient(135deg,#fffaf0,#f8f0e1);color:#8a5c18}.discount-status-banner.status-negotiated .discount-banner__eyebrow{color:#8a5c18}.discount-status-banner.status-negotiated .discount-banner__value{border-color:#eadbc1;background:rgba(255,255,255,.72)}.discount-status-banner.status-approved{border-color:#b5ddc5;background:linear-gradient(135deg,#f3fff7,#e9f8ef);color:#19633d}.discount-status-banner.status-approved .discount-banner__eyebrow{color:#19633d}.discount-status-banner.status-approved .discount-banner__value{border-color:#c9e8d4;background:rgba(255,255,255,.72)}
    .discount-banner__actions{grid-column:1/-1;display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.discount-banner__actions .btn{font-weight:800}
    .discount-status-banner.status-client_accepted{border-color:#bcd0e6;background:linear-gradient(135deg,#f5f9ff,#eaf1fb);color:#1d4f86}.discount-status-banner.status-client_accepted .discount-banner__eyebrow{color:#1d4f86}.discount-status-banner.status-client_accepted .discount-banner__value{border-color:#d3e1f1;background:rgba(255,255,255,.78)}
    .discount-status.accepted{background:#dbeafe;color:#1e40af}
    .discount-request-note{margin:10px 0 0;padding:9px 11px;border-radius:12px;font-size:12px;font-weight:800;line-height:1.7}.discount-request-note.wait{background:#fff4d2;color:#725200;border:1px solid #ecd9a0}.discount-request-note.accepted{background:#dbeafe;color:#1e40af;border:1px solid #bcd0e6}.discount-request-note.approved{background:#dcfce7;color:#166534;border:1px solid #b5ddc5}.discount-request-note.rejected{background:#fee2e2;color:#991b1b;border:1px solid #f0bcbc}
    @media(max-width:900px){.discount-status-banner{grid-template-columns:1fr;padding:20px}.discount-banner__values{grid-template-columns:1fr}.discount-banner__intro h2{font-size:22px}}
