/* Code Craft — Client Dashboard styles (loads after style.css for vars/buttons) */
.dash{display:grid;grid-template-columns:264px 1fr;min-height:100vh;background:var(--soft)}
.dash__side{background:var(--navy);color:#cdd7e6;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow-y:auto}
.dash__brand{display:flex;align-items:center;gap:10px;padding:20px 22px;border-bottom:1px solid rgba(255,255,255,.08)}
.dash__brand img{height:30px}
.dash__brand b{color:#fff;font-weight:800;font-size:1.05rem}
.dash__nav{padding:14px 12px;display:grid;gap:3px;flex:1}
.dash__nav a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;color:#aebbcd;font-weight:600;font-size:.92rem;transition:background .2s,color .2s}
.dash__nav a .ico{font-size:1.1rem;width:22px;text-align:center}
.dash__nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.dash__nav a.active{background:var(--grad-blue);color:#fff;box-shadow:var(--shadow-blue)}
.dash__navhead{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#6f8198;font-weight:800;padding:14px 16px 6px}
.dash__side-cta{margin:10px 14px 18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:16px}
.dash__side-cta p{font-size:.82rem;color:#aebbcd;margin-bottom:10px}
.dash__main{display:flex;flex-direction:column;min-width:0}
.dash__top{background:#fff;border-bottom:1px solid var(--line);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:0;z-index:20}
.dash__top h1{font-size:1.2rem;margin:0}
.dash__top-r{display:flex;align-items:center;gap:14px}
.dash__icon-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);background:var(--soft);display:grid;place-items:center;cursor:pointer;position:relative;color:var(--muted)}
.dash__icon-btn:hover{color:var(--primary);border-color:var(--primary-l2)}
.dash__icon-btn .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--green);border:2px solid #fff}
.dash__user{display:flex;align-items:center;gap:10px;cursor:pointer}
.dash__avatar{width:40px;height:40px;border-radius:50%;background:var(--grad-blue);color:#fff;display:grid;place-items:center;font-weight:800}
.dash__user small{display:block;color:var(--muted);font-size:.76rem}
.dash__user strong{font-size:.9rem;color:var(--ink)}
.dash__body{padding:28px;display:grid;gap:22px}
.dash__menu-btn{display:none}

/* widgets */
.d-grid{display:grid;gap:20px}
.d-grid--4{grid-template-columns:repeat(4,1fr)}
.d-grid--3{grid-template-columns:repeat(3,1fr)}
.d-grid--2{grid-template-columns:repeat(2,1fr)}
.d-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow)}
.d-card__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px}
.d-card__head h3{font-size:1.02rem;margin:0}
.d-stat{display:flex;flex-direction:column;gap:6px}
.d-stat__ico{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:1.3rem;background:var(--soft-2);margin-bottom:4px}
.d-stat__num{font-size:1.9rem;font-weight:900;color:var(--ink);line-height:1}
.d-stat__lb{font-size:.83rem;color:var(--muted);font-weight:600}
.d-stat__chg{font-size:.78rem;font-weight:700}
.d-stat__chg.up{color:var(--green)}.d-stat__chg.down{color:#e5484d}
.d-bars{display:flex;align-items:flex-end;gap:10px;height:160px;padding-top:10px}
.d-bars div{flex:1;background:var(--grad-blue);border-radius:7px 7px 0 0;position:relative;min-height:6px;transition:height .6s}
.d-bars div span{position:absolute;top:-20px;left:0;right:0;text-align:center;font-size:.7rem;color:var(--muted);font-weight:700}
.d-bars div em{position:absolute;bottom:-22px;left:0;right:0;text-align:center;font-size:.7rem;color:var(--muted);font-style:normal}
.d-table{width:100%;border-collapse:collapse;font-size:.9rem}
.d-table th{text-align:left;color:var(--muted);font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.04em;padding:10px 12px;border-bottom:2px solid var(--line)}
.d-table td{padding:12px;border-bottom:1px solid var(--line);color:var(--text)}
.d-table tr:last-child td{border-bottom:0}
.d-table tr:hover td{background:var(--soft)}
.badge{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;font-weight:800;padding:3px 10px;border-radius:999px}
.badge--green{background:#e7f7ef;color:#0e7a44}.badge--blue{background:#e8f1fd;color:#0C57AD}
.badge--amber{background:#fef3e2;color:#b76e00}.badge--gray{background:var(--soft-2);color:var(--muted)}
.badge--red{background:#fdeaea;color:#c92a2a}
.chg{font-weight:800;font-size:.82rem}.chg.up{color:var(--green)}.chg.down{color:#e5484d}
.d-progress{height:9px;border-radius:999px;background:var(--soft-2);overflow:hidden}
.d-progress span{display:block;height:100%;background:var(--grad-green);border-radius:999px}
/* stepper */
.stepper{display:grid;gap:0}
.stepper__row{display:grid;grid-template-columns:34px 1fr;gap:14px;position:relative;padding-bottom:22px}
.stepper__row:not(:last-child)::before{content:"";position:absolute;left:16px;top:30px;bottom:0;width:2px;background:var(--line)}
.stepper__row.done:not(:last-child)::before{background:var(--green)}
.stepper__dot{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:.85rem;background:var(--soft-2);color:var(--muted);z-index:1}
.stepper__row.done .stepper__dot{background:var(--grad-green);color:#fff}
.stepper__row.active .stepper__dot{background:var(--grad-blue);color:#fff;box-shadow:var(--shadow-blue)}
.stepper__t{font-weight:700;color:var(--ink)}
.stepper__d{font-size:.84rem;color:var(--muted)}
/* upload + files */
.upload{border:2px dashed var(--primary-l2);border-radius:14px;padding:32px 20px;text-align:center;background:var(--soft);cursor:pointer;transition:background .2s,border-color .2s}
.upload:hover,.upload.drag{background:#eaf2fd;border-color:var(--primary)}
.upload__ico{font-size:2rem}
.upload p{color:var(--muted);font-size:.9rem;margin-top:6px}
.upload strong{color:var(--primary)}
.filelist{display:grid;gap:10px;margin-top:16px}
.filerow{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:11px;background:#fff}
.filerow__ico{width:36px;height:36px;border-radius:9px;background:var(--soft-2);display:grid;place-items:center;font-size:1.1rem;flex:0 0 auto}
.filerow__meta{flex:1;min-width:0}
.filerow__meta strong{display:block;font-size:.9rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.filerow__meta small{color:var(--muted);font-size:.78rem}
.activity{display:grid;gap:0}
.activity__row{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--line)}
.activity__row:last-child{border-bottom:0}
.activity__dot{width:34px;height:34px;border-radius:9px;background:var(--soft-2);display:grid;place-items:center;flex:0 0 auto}
.activity__row p{font-size:.9rem;color:var(--text)}
.activity__row small{color:var(--muted);font-size:.76rem}
.svc-pill{display:inline-flex;align-items:center;gap:7px;background:var(--soft-2);border-radius:999px;padding:6px 13px;font-size:.82rem;font-weight:700;color:var(--ink)}
@media(max-width:1080px){.d-grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:980px){
  .dash{grid-template-columns:1fr}
  .dash__side{position:fixed;left:0;top:0;width:264px;z-index:60;transform:translateX(-100%);transition:transform .3s;box-shadow:0 0 60px rgba(0,0,0,.4)}
  .dash.open .dash__side{transform:none}
  .dash__menu-btn{display:grid}
  .dash__backdrop{display:none;position:fixed;inset:0;background:rgba(8,16,30,.5);z-index:55}
  .dash.open .dash__backdrop{display:block}
}
@media(max-width:760px){.d-grid--4,.d-grid--3,.d-grid--2{grid-template-columns:1fr}.dash__body{padding:18px}.dash__user small{display:none}}

/* ===== client/admin auth pages (login / register) ===== */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr}
.auth__brand{background:var(--navy);color:#fff;padding:54px 56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth__brand::after{content:"";position:absolute;right:-120px;top:-80px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(32,125,233,.5),transparent 70%)}
.auth__brand::before{content:"";position:absolute;left:-100px;bottom:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(14,146,81,.4),transparent 70%)}
.auth__logo{display:flex;align-items:center;gap:11px;position:relative;z-index:1}.auth__logo img{height:36px}.auth__logo b{font-size:1.2rem;font-weight:800}
.auth__brand h2{font-size:2rem;line-height:1.2;margin:0 0 14px;position:relative;z-index:1}
.auth__brand p{color:#aebbcd;position:relative;z-index:1;max-width:380px}
.auth__pts{display:grid;gap:12px;margin-top:22px;position:relative;z-index:1;padding:0}
.auth__pts li{display:flex;gap:10px;align-items:center;color:#cdd7e6;font-size:.92rem;list-style:none}
.auth__pts svg{width:20px;height:20px;color:#41D48C;flex:0 0 auto}
.auth__form{display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--soft)}
.auth__card{width:100%;max-width:400px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:38px 34px;box-shadow:var(--shadow-lg)}
.auth__card h1{font-size:1.5rem;margin:0 0 4px}
.auth__card .sub{color:var(--muted);font-size:.92rem;margin-bottom:24px}
.auth__field{margin-bottom:15px}
.auth__field label{display:block;font-size:.82rem;font-weight:700;color:var(--ink);margin-bottom:6px}
.auth__field input{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:var(--soft)}
.auth__field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-l);background:#fff}
.auth .btn{width:100%}
.auth__or{text-align:center;color:var(--muted);font-size:.8rem;margin:18px 0;position:relative}
.auth__or::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--line)}
.auth__or span{background:#fff;padding:0 12px;position:relative}
.auth__social button{display:flex;align-items:center;justify-content:center;gap:10px;padding:11px;border:1px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-weight:700;font-size:.88rem;cursor:pointer;color:var(--ink);width:100%}
.auth__social button:hover{background:var(--soft)}
.auth__social svg{width:18px;height:18px}
.auth__note{font-size:.82rem;color:var(--muted);text-align:center;margin-top:20px}
.auth__back{position:relative;z-index:1;color:#aebbcd;font-size:.85rem}.auth__back:hover{color:#fff}
@media(max-width:860px){.auth{grid-template-columns:1fr}.auth__brand{display:none}}
