/* ITAspects Client Onboarding, brand palette aligned to logo */
:root{
  --primary:#2A6FD4;
  --primary-dark:#2C2EBE;
  --primary-deep:#1A1F8C;
  --accent:#1FA8E8;
  --accent-2:#0BBBE2;
  --magenta:#A1267D;
  --magenta-2:#7B2E9A;
  --gradient-brand:linear-gradient(90deg,#A1267D 0%,#7B2E9A 22%,#1FA8E8 48%,#2A6FD4 75%,#2C2EBE 100%);
  --gradient-blue:linear-gradient(135deg,#1FA8E8 0%,#2A6FD4 50%,#2C2EBE 100%);
  --gradient-purple:linear-gradient(135deg,#A1267D 0%,#7B2E9A 100%);
  --dark:#0F1B2D;
  --grey:#5C6B7A;
  --grey-light:#94A3B5;
  --mist:#E7EEF6;
  --light:#F5F8FB;
  --cloud:#FAFCFD;
  --white:#FFFFFF;
  --green:#1FAA59;
  --red:#E63946;
  --orange:#FF7A1A;
  --shadow-sm:0 2px 8px rgba(15,27,45,.08);
  --shadow:0 12px 32px rgba(15,27,45,.12);
  --shadow-lg:0 24px 60px rgba(15,27,45,.18);
  --radius:12px;
  --radius-lg:18px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter','Segoe UI',sans-serif;color:var(--dark);background:var(--light);line-height:1.6;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{font-family:'Manrope','Segoe UI',sans-serif;line-height:1.15;color:var(--dark);font-weight:800;letter-spacing:-.02em;}
a{color:var(--primary);text-decoration:none;}
a:hover{color:var(--primary-dark);}

/* HEADER */
.app-header{background:#fff;color:var(--dark);padding:20px 0;position:sticky;top:0;z-index:50;box-shadow:0 1px 0 var(--mist);border-bottom:3px solid transparent;border-image:var(--gradient-brand) 1;}
.app-header .row{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;}
.brand{display:flex;align-items:center;gap:14px;}
.brand-logo{height:48px;width:auto;display:block;}
.brand-tag{font-family:'Manrope';font-weight:700;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--grey);padding-left:14px;border-left:1.5px solid var(--mist);}
.header-cta{display:flex;gap:12px;align-items:center;font-size:14px;color:var(--grey);}
.header-cta strong{color:var(--primary-dark);font-weight:700;}
.header-cta{display:flex;gap:12px;align-items:center;font-size:14px;color:rgba(255,255,255,.85);}
.header-cta strong{color:#fff;font-weight:700;}

/* CONTAINER */
.wrap{max-width:1000px;margin:0 auto;padding:32px 24px 80px;}

/* HERO */
.hero{background:#fff;border-radius:var(--radius-lg);padding:44px;box-shadow:var(--shadow-sm);margin-bottom:24px;position:relative;overflow:hidden;border:1px solid var(--mist);}
.hero::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-brand);}
.hero::after{content:"";position:absolute;top:-50%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(161,38,125,.06) 0%,rgba(42,111,212,.05) 50%,transparent 70%);pointer-events:none;}
.hero h1{font-size:34px;margin-bottom:10px;background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;display:inline-block;}
.hero p.lede{font-size:17px;color:var(--grey);max-width:680px;}
.hero .meta{display:flex;gap:16px;flex-wrap:wrap;margin-top:20px;font-size:14px;color:var(--grey);}
.hero .meta span{display:inline-flex;align-items:center;gap:6px;background:var(--light);padding:6px 12px;border-radius:8px;}
.hero .meta strong{color:var(--primary);font-weight:700;}

/* PROGRESS */
.progress-bar{position:sticky;top:96px;z-index:40;background:var(--light);padding:14px 0;margin:-32px -24px 24px;border-bottom:1px solid var(--mist);}
.progress-inner{max-width:1000px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:14px;font-size:13px;color:var(--grey);font-weight:600;}
.progress-track{flex:1;height:6px;background:var(--mist);border-radius:99px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));width:0%;transition:width .4s ease;border-radius:99px;}
.progress-status{display:flex;align-items:center;gap:6px;color:var(--green);font-weight:700;font-size:12px;}
.progress-status.saving{color:var(--orange);}

/* CARD */
.card{background:#fff;border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-sm);margin-bottom:20px;border:1px solid var(--mist);transition:box-shadow .2s;}
.card:hover{box-shadow:var(--shadow);}
.card-head{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--mist);cursor:pointer;}
.card-head .num{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:grid;place-items:center;font-family:'Manrope';font-weight:800;flex-shrink:0;}
.card-head h2{font-size:21px;flex:1;}
.card-head .sub{font-size:13px;color:var(--grey);font-weight:500;margin-top:2px;}
.card-head .toggle{width:32px;height:32px;background:var(--light);border-radius:8px;display:grid;place-items:center;transition:transform .25s,background .2s;color:var(--primary);font-size:18px;font-weight:300;}
.card.collapsed .toggle{transform:rotate(-90deg);}
.card.collapsed .card-body{display:none;}
.card.optional{opacity:.55;}
.card.optional.active{opacity:1;}
.card.optional .card-head .num{background:linear-gradient(135deg,var(--grey-light),var(--grey));}
.card.optional.active .card-head .num{background:linear-gradient(135deg,var(--primary),var(--primary-dark));}

/* FIELDS */
.field{margin-bottom:18px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field-row.three{grid-template-columns:1fr 1fr 1fr;}
label{display:block;font-size:13px;font-weight:700;color:var(--dark);margin-bottom:7px;letter-spacing:.2px;}
label .req{color:var(--red);margin-left:3px;}
label .help{display:block;font-weight:500;color:var(--grey);font-size:12px;margin-top:3px;}
input[type=text],input[type=email],input[type=tel],input[type=url],input[type=number],input[type=date],select,textarea{width:100%;padding:13px 16px;border:1.5px solid var(--mist);background:#fff;border-radius:10px;font-size:14.5px;font-family:'Inter';color:var(--dark);transition:all .2s;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px rgba(0,115,209,.1);}
textarea{min-height:96px;resize:vertical;}
input::placeholder,textarea::placeholder{color:var(--grey-light);}

/* CHECKBOXES & RADIOS */
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.checks.three{grid-template-columns:repeat(3,1fr);}
.checks.four{grid-template-columns:repeat(4,1fr);}
.check-card{position:relative;cursor:pointer;}
.check-card input{position:absolute;opacity:0;}
.check-card .face{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border:1.5px solid var(--mist);border-radius:10px;font-size:14px;font-weight:600;color:var(--dark);transition:all .2s;}
.check-card .face::before{content:"";width:18px;height:18px;border:1.5px solid var(--mist);border-radius:5px;background:#fff;flex-shrink:0;transition:all .2s;}
.check-card input:checked + .face{border-color:var(--primary);background:rgba(0,115,209,.06);color:var(--primary);}
.check-card input:checked + .face::before{background:var(--primary);border-color:var(--primary);content:"✓";color:#fff;font-weight:bold;text-align:center;line-height:14px;font-size:13px;}

/* SERVICE TILES */
.service-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.svc-tile{position:relative;cursor:pointer;}
.svc-tile input{position:absolute;opacity:0;}
.svc-tile .face{padding:20px;background:#fff;border:2px solid var(--mist);border-radius:14px;text-align:center;transition:all .25s;}
.svc-tile .icon{width:54px;height:54px;border-radius:12px;background:var(--light);display:grid;place-items:center;margin:0 auto 12px;transition:all .25s;}
.svc-tile .icon svg{width:26px;height:26px;color:var(--primary);}
.svc-tile h4{font-size:15px;margin-bottom:4px;}
.svc-tile p{font-size:12px;color:var(--grey);}
.svc-tile input:checked + .face{border-color:var(--primary);background:linear-gradient(180deg,rgba(0,115,209,.05),#fff);transform:translateY(-3px);box-shadow:var(--shadow);}
.svc-tile input:checked + .face .icon{background:var(--primary);}
.svc-tile input:checked + .face .icon svg{color:#fff;}
.svc-tile input:checked + .face::after{content:"✓";position:absolute;top:8px;right:12px;width:22px;height:22px;background:var(--primary);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:bold;}

/* RADIO PILLS */
.radio-pills{display:flex;gap:10px;flex-wrap:wrap;}
.radio-pills label{margin:0;cursor:pointer;}
.radio-pills input{position:absolute;opacity:0;}
.radio-pills .pill{display:inline-block;padding:9px 18px;background:#fff;border:1.5px solid var(--mist);border-radius:99px;font-size:13.5px;font-weight:600;color:var(--dark);transition:all .2s;}
.radio-pills input:checked ~ .pill{background:var(--primary);border-color:var(--primary);color:#fff;}

/* TAGS INPUT */
.tags-input{padding:8px 8px 4px;display:flex;flex-wrap:wrap;gap:6px;align-items:center;border:1.5px solid var(--mist);background:#fff;border-radius:10px;min-height:50px;}
.tags-input:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px rgba(0,115,209,.1);}
.tag{display:inline-flex;align-items:center;gap:6px;background:rgba(0,115,209,.12);color:var(--primary);padding:5px 10px;border-radius:8px;font-size:13px;font-weight:600;}
.tag .x{cursor:pointer;font-weight:bold;color:var(--primary);opacity:.7;}
.tag .x:hover{opacity:1;}
.tags-input input{flex:1;min-width:140px;border:none !important;box-shadow:none !important;padding:6px 8px !important;background:transparent !important;}

/* NOTICE BOXES */
.notice{padding:14px 18px;border-radius:10px;font-size:13.5px;margin-bottom:18px;display:flex;gap:12px;align-items:flex-start;}
.notice .ico{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:bold;color:#fff;}
.notice.info{background:rgba(0,115,209,.08);color:var(--primary-deep);}
.notice.info .ico{background:var(--primary);content:"i";}
.notice.warn{background:rgba(255,122,26,.1);color:#8B4513;}
.notice.warn .ico{background:var(--orange);}
.notice.secure{background:rgba(31,170,89,.1);color:#0F5A2E;}
.notice.secure .ico{background:var(--green);}

/* FOOTER ACTIONS */
.footer-actions{background:#fff;border:1px solid var(--mist);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow);position:sticky;bottom:20px;margin-top:24px;}
.footer-actions .row{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;}
.footer-actions h3{font-size:16px;margin-bottom:4px;}
.footer-actions p{font-size:13.5px;color:var(--grey);}
.footer-actions .buttons{display:flex;gap:10px;flex-wrap:wrap;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border-radius:10px;font-weight:700;font-size:14.5px;cursor:pointer;border:none;font-family:'Inter';transition:all .2s ease;text-decoration:none;}
.btn-primary{background:var(--primary);color:#fff;}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,115,209,.3);}
.btn-secondary{background:#fff;color:var(--primary);border:1.5px solid var(--mist);}
.btn-secondary:hover{border-color:var(--primary);background:rgba(0,115,209,.04);}
.btn-success{background:var(--green);color:#fff;}
.btn-success:hover{filter:brightness(1.08);}
.btn-ghost{background:transparent;color:var(--grey);}
.btn-ghost:hover{color:var(--dark);background:var(--light);}

/* CHIPS for service indicator at top */
.service-status{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;}
.svc-chip{padding:5px 12px;background:var(--light);border:1.5px solid var(--mist);border-radius:99px;font-size:12.5px;font-weight:600;color:var(--grey-light);transition:all .2s;}
.svc-chip.on{background:rgba(0,115,209,.12);border-color:var(--primary);color:var(--primary);}

/* HELPER ROWS */
.access-grid{display:grid;grid-template-columns:1.5fr 1fr 1.5fr;gap:14px;align-items:center;padding:12px 14px;background:var(--light);border-radius:10px;margin-bottom:8px;font-size:13.5px;}
.access-grid:first-of-type{font-weight:700;color:var(--grey);font-size:12px;text-transform:uppercase;letter-spacing:1px;background:transparent;padding-bottom:0;}
.access-grid select{padding:9px 12px;font-size:13.5px;}

/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(15,27,45,.65);backdrop-filter:blur(6px);z-index:200;display:none;align-items:center;justify-content:center;padding:24px;}
.modal-bg.open{display:flex;animation:fadeIn .25s;}
.modal{background:#fff;border-radius:var(--radius-lg);max-width:600px;width:100%;padding:36px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;}
.modal h2{margin-bottom:8px;}
.modal p{color:var(--grey);margin-bottom:20px;font-size:14.5px;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}

/* SUCCESS SCREEN */
.success-screen{text-align:center;padding:80px 40px;}
.success-screen .check{width:80px;height:80px;border-radius:50%;background:var(--green);color:#fff;font-size:40px;display:grid;place-items:center;margin:0 auto 24px;}
.success-screen h2{font-size:28px;margin-bottom:10px;}
.success-screen p{font-size:16px;color:var(--grey);max-width:480px;margin:0 auto 28px;}
.ref-id{display:inline-block;font-family:'JetBrains Mono',monosp