:root{
    --bg: #F6F7FB;
    --card: #ffffff;
    --ink: #111827;
    --ink-2:#374151;
    --ink-3:#6B7280;
    --ink-4:#9CA3AF;
    --line:#E5E7EB;
    --line-2:#EEF2F7;
    --brand:#2563EB;
    --brand-2:#3B82F6;
    --brand-weak:#EFF6FF;
    --success:#10B981;
    --danger:#EF4444;
  
    --r-2: 6px;
    --r-3: 8px;
    --r-4:10px;
    --r-5:12px;
  
    --sh-1: 0 1px 2px rgba(17, 24, 39, .06);
    --sh-2: 0 6px 18px rgba(17, 24, 39, .06);
    --ring: 0 0 0 3px rgba(37,99,235,.15);
  }
  
/* stabilna širina — nema skakanja kada se pojavi/ukloni skrol traka */
html{ scrollbar-gutter: stable both-edges; }
/* fallback za starije browsere */
@supports not (scrollbar-gutter: stable both-edges){
  html{ overflow-y: scroll; }
}

/* zajedničke vrednosti da sve kartice imaju isti “gutter” */
:root{
  --container-max: 1120px;
  --gutter: 20px;
}


  *{box-sizing:border-box;margin:0;padding:0}
  html,body{height:100%}
  body{
    font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    background:
      radial-gradient(1000px 600px at -10% -20%, #FFFFFF 0%, rgba(255,255,255,0) 60%),
      radial-gradient(900px 500px at 120% -10%, #EEF2FF 0%, rgba(238,242,255,0) 55%),
      var(--bg);
    color:var(--ink);
    line-height:1.55;
    letter-spacing: 0.01em;
    display:flex; flex-direction:column; min-height:100vh;
  }
  body.sheet-open{ overflow:hidden; }
  
  .container{
    max-width: var(--container-max);
    width: 100%;
    margin-inline: auto;
    padding-block: 28px;
    padding-inline: var(--gutter);
    flex: 1;
  }
  
  /* Header */
  .header{
    background:var(--card);
    padding:18px 20px;
    border-radius: var(--r-4);
    border:1px solid var(--line);
    box-shadow: var(--sh-1);
    margin-bottom:24px;
    display:flex;justify-content:space-between;align-items:center;gap:16px
  }
  .brand{ display:flex;align-items:center;gap:12px }
  .brand-logo{
    width:34px;height:34px;border-radius:10px;
    background: linear-gradient(180deg, #3B82F6 0%, #2563EB 100%);
    display:grid;place-items:center;color:#fff;font-weight:700;box-shadow: var(--sh-1)
  }
  .brand h1{font-size:22px;font-weight:700;letter-spacing:.01em}
  
  .toolbar{display:flex;gap:12px;align-items:center}
  .search{
    display:flex;align-items:center;gap:8px;
    border:1px solid var(--line);
    background:#FBFCFE;
    border-radius: var(--r-3);
    padding:8px 12px;
    min-width:260px;
    transition:border-color .2s, background .2s
  }
  .search input{
    border:0;outline:0;background:transparent;width:100%;
    font: 500 14px/1.4 'Inter', sans-serif;color:var(--ink-2)
  }
  
  .btn{
    padding:10px 16px;border:1px solid var(--line);border-radius: var(--r-2);
    font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s, box-shadow .15s, background .15s, border-color .15s;
    display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--ink-2)
  }
  .btn:hover{transform:translateY(-1px);box-shadow: var(--sh-1)}
  .btn:focus-visible{outline:none;box-shadow: var(--ring)}
  .btn-primary{background:var(--brand-2);border-color:transparent;color:#fff}
  .btn-primary:hover{background:var(--brand)}
  .btn-ghost{background:#F8FAFC}
  
  /* File status pill */
  .file-status{
    display:inline-flex;align-items:center;gap:8px;padding:6px 10px;
    background:var(--brand-weak);color:var(--brand);border-radius: var(--r-2);
    font-size:12px;font-weight:600;border:1px solid #DBEAFE;margin-top:6px
  }
  .file-status > *{display:inline-flex;align-items:center}
  
  /* Tekstualna dugmad */
  .link-btn{
    background:transparent;border:0;padding:0 8px;height:24px;
    display:inline-flex;align-items:center;font-weight:600;font-size:13px;color:#2563EB;cursor:pointer;border-radius:6px
  }
  .link-btn:hover{ background:#EEF2FF; }
  .link-danger{ color:#EF4444; }
  
  /* Akcije desno od imena fajla */
  .file-status-actions{ display:inline-flex;align-items:center;gap:6px;margin-left:6px }
  
  /* Grid */
  .projects-wrap{
    background:var(--card);border:1px solid var(--line);border-radius: var(--r-4);box-shadow: var(--sh-1);
    padding:20px
  }
  .projects-grid{ display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-top:12px }
  .project-card{
    background:#fff;border:1px solid var(--line);border-radius: var(--r-4);
    padding:18px;transition: border-color .2s, transform .2s, box-shadow .2s;position:relative;cursor:pointer
  }
  .project-card:hover{border-color:#C7D2FE;box-shadow: var(--sh-2);transform:translateY(-2px)}
  .project-card h3{font-size:18px;font-weight:600;margin-bottom:6px;color:#0F172A}
  .project-card p{color:var(--ink-3);font-size:13.5px;margin-bottom:12px}
  .project-meta{ display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--ink-4) }
  .credential-count{background:#F1F6FF;color:var(--brand);padding:3px 10px;border-radius:999px;font-weight:700;border:1px solid #E3ECFF}
  
  .project-actions{ position:absolute;top:12px;right:12px;display:flex;gap:6px;opacity:0;transition:opacity .2s }
  .project-card:hover .project-actions{opacity:1}
  .icon-btn{
    width:30px;height:30px;border:1px solid var(--line);border-radius:8px;background:#F8FAFC;
    display:grid;place-items:center;cursor:pointer;transition:transform .15s, background .15s, border-color .15s
  }
  .icon-btn:hover{transform:scale(1.06)}
  .icon-btn.edit{color:var(--brand)}
  .icon-btn.delete{color:var(--danger)}
  .icon-btn.edit:hover{background:#F3F6FC;border-color:#DDE5FF}
  .icon-btn.delete:hover{background:#FEF2F2;border-color:#FECACA}
  
  /* Detail view */
  .header-slim{
    background:var(--card);padding:12px 16px;border-radius: var(--r-4);
    border:1px solid var(--line);box-shadow: var(--sh-1);display:flex;justify-content:space-between;align-items:center;margin-bottom:16px
  }
  .detail-actions{ display:flex; gap:8px; align-items:center; }
  .btn-back{background:transparent;border:0;color:var(--ink-3);padding:8px 8px;border-radius: var(--r-2)}
  .btn-back:hover{background:#F3F4F6;color:var(--brand)}
  
  .project-detail{ background:var(--card);border-radius: var(--r-4);padding:22px;border:1px solid var(--line);box-shadow: var(--sh-1) }
  .project-header-detail{border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:20px}
  .project-header-detail h2{font-size:26px;font-weight:700;margin-bottom:6px;color:#0F172A}
  .project-header-detail p{color:var(--ink-3);font-size:15px}
  
  /* Client Info embed card (minimalno) */
  .clientinfo-section{ margin-bottom:16px; }
  .clientinfo-embed{
    display:flex;justify-content:space-between;align-items:center;gap:16px;
    background:#FBFCFE;border:1px solid var(--line);border-radius: var(--r-4);
    padding:16px 18px;box-shadow: var(--sh-1)
  }
  .clientinfo-embed .ci-left{ display:flex; gap:12px; align-items:center; }
  .ci-icon{
    width:36px;height:36px;border-radius:10px;display:grid;place-items:center;
    background:#EEF2FF;border:1px solid #E0E7FF;font-size:18px
  }
  .ci-text h3{ font-size:16px; font-weight:700; color:#0F172A; }
  
  /* Sections */
  .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
  .section-header h3{font-size:16px;font-weight:700;color:#0F172A}
  
  .credentials-section{margin-top:18px}
  .credential-item{
    background:#FBFCFE;border:1px solid var(--line);border-radius: var(--r-4);
    padding:18px;margin-bottom:12px;transition:border-color .2s, transform .2s
  }
  .credential-item:hover{border-color:#C7D2FE;transform:translateY(-1px)}
  .credential-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
  .credential-info-label{font-size:15px;font-weight:700;color:#111827}
  .credential-field{margin-bottom:12px}
  .credential-label{ font-size:11px;font-weight:700;color:#6B7280;text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px }
  .credential-value-row{display:flex;gap:8px;align-items:center}
  .credential-value{
    flex:1;background:#fff;padding:10px 12px;border-radius: var(--r-3);border:1px solid var(--line);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size:13.5px;color:#0F172A;overflow:auto;white-space:nowrap
  }
  .btn-copy{
    padding:9px 12px;background:var(--brand);color:#fff;border:0;border-radius: var(--r-2);
    cursor:pointer;font-weight:700;font-size:12.5px;transition:filter .15s, transform .15s
  }
  .btn-copy:hover{filter:brightness(.95);transform:translateY(-1px)}
  .btn-copy.copied{background:var(--success)}
  
  .hidden{display:none !important}
  
  /* Modal base */
  .modal{display:none;position:fixed;inset:0;background:rgba(15,23,42,.35);z-index:1000;align-items:center;justify-content:center;padding:16px}
  .modal.active{display:flex}
  .modal-content{
    background:#fff;border-radius:14px;padding:22px;max-width:560px;width:100%;
    max-height:85vh;overflow:auto;box-shadow: 0 20px 40px rgba(2,6,23,.18);border:1px solid var(--line)
  }
  /* Wider variant for Client Info */
  .modal-content-wide{ max-width:900px; width:min(900px, 96vw); }
  .modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
  .modal-header h3{font-size:18px;font-weight:700}
  .close-modal{width:30px;height:30px;border:1px solid var(--line);background:#F8FAFC;border-radius:8px;cursor:pointer;font-size:18px;color:#6B7280}
  .close-modal:hover{background:#EEF2F7}
  
  .form-group{margin-bottom:14px}
  .form-group label{display:block;font-size:13px;font-weight:700;color:#374151;margin-bottom:6px}
  .form-group input,.form-group textarea{
    width:100%;padding:10px 12px;border:1px solid var(--line);border-radius: var(--r-3);
    font-size:14px;transition:border-color .2s, box-shadow .2s;background:#fff
  }
  .form-group input:focus,.form-group textarea:focus{outline:none;border-color:#C7D2FE;box-shadow: var(--ring)}
  .form-group textarea{resize:vertical;min-height:96px}
  .modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}

  /* Client Info modal: layout and sticky footer actions */
  #clientInfoModal .modal-content{ display:flex; flex-direction:column; }
  #clientInfoModal .form-group{ flex:1; display:flex; flex-direction:column; }
  #clientInfoModal .ci-textarea{
    flex:1; min-height:280px; height:50vh; resize:vertical;
    border:1px solid var(--line); border-radius: var(--r-3);
    font: 14px/1.6 ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    padding:12px;
  }
  #clientInfoModal .ci-textarea:focus{ outline:none; border-color:#C7D2FE; box-shadow: var(--ring); }
  #clientInfoModal .modal-actions{
    position:sticky; bottom:0; background:#fff; padding-top:12px; margin-top:14px;
    border-top:1px solid var(--line);
  }
  
  /* Empty state */
  .empty-wrap{
    border:1px dashed #D6DBE6;border-radius: var(--r-4);padding:28px;background:
      linear-gradient(180deg,#FFFFFF 0%, #FAFBFF 100%);
    position:relative;overflow:hidden
  }
  .empty-wrap::after{
    content:"";position:absolute;inset:-1px;border-radius:inherit;
    background-image:
      radial-gradient(#E8ECF7 1px, transparent 1px),
      radial-gradient(#EEF2F8 1px, transparent 1px);
    background-size:18px 18px, 36px 36px;
    background-position:0 0, 8px 8px;opacity:.45;pointer-events:none
  }
  .empty-state{text-align:center;position:relative;z-index:1}
  .empty-state-icon{font-size:48px;margin-bottom:8px}
  .empty-state h3{font-size:15.5px;color:#374151;margin-bottom:4px;font-weight:700}
  .empty-state p{color:#6B7280;font-size:13.5px}
  .empty-actions{margin-top:14px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
  
  /* Reconnect banner */
  .reconnect-banner{
    display:flex;justify-content:space-between;align-items:center;gap:12px;
    background:#F8FAFF;border:1px solid #DBEAFE;color:#1E3A8A;
    padding:12px 16px;border-radius:10px;box-shadow: 0 1px 2px rgba(17,24,39,.06);
    margin-bottom:12px
  }
  .reconnect-banner .rc-info{display:flex;align-items:center;gap:10px}
  .reconnect-banner .rc-text strong{display:block;font-size:14px}
  .reconnect-banner .rc-text span{font-size:12.5px;color:#475569}
  .reconnect-banner .rc-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
  
  /* ===== Client Info SIDE SHEET (jednostavno) ===== */
  .sheet{ position:fixed; inset:0; z-index:1100; display:none; }
  .sheet.active{ display:block; }
  .sheet-backdrop{ position:absolute; inset:0; background:rgba(15,23,42,.35); }
  .sheet-panel{
    position:absolute; top:0; right:0; height:100%; width:min(820px, 100%);
    background:#fff; border-left:1px solid var(--line); box-shadow: -20px 0 40px rgba(2,6,23,.18);
    display:flex; flex-direction:column;
  }
  .sheet-header{
    display:flex; align-items:center; justify-content:space-between; gap:12px;
    padding:14px 16px; border-bottom:1px solid var(--line); background:#fff;
  }
  .sheet-header h3{ font-size:16px; font-weight:700; color:#0F172A }
  .sheet-right{ display:flex; align-items:center; gap:8px; }
  
  .sheet-body{ flex:1; overflow:auto; padding:16px; }
  #ciEditor{
    width:100%; height:calc(100vh - 200px); min-height:320px; resize:vertical;
    border:1px solid var(--line); border-radius:10px; padding:12px;
    font: 14px/1.6 ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  }
  #ciEditor:focus{ outline:none; box-shadow: var(--ring); border-color:#C7D2FE }
  

  .app-footer{
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--r-4);
    box-shadow: var(--sh-1);
    padding: 16px 18px;
    margin-top: 24px;
    text-align: center;
  }
  
  .app-footer .footer-title{
    font-size: 14px;
    font-weight: 700;
    color: var(--ink-2);
  }
  
  .app-footer .footer-brand{
    color: var(--brand);
  }
  
  .app-footer .footer-note{
    margin-top: 6px;
    font-size: 13px;
    color: var(--ink-3);
    max-width: 880px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.6;
  }
  

  /* === Onboarding (prvo pokretanje) === */
.onb-card{
    border:1px solid var(--line);
    border-radius: var(--r-4);
    background: linear-gradient(180deg,#FFFFFF 0%, #FAFBFF 100%);
    box-shadow: var(--sh-1);
    padding: 22px var(--gutter);
    text-align: center;
  }
  
  .onb-icon{
    width:48px; height:48px; margin: 0 auto 8px;
    display:grid; place-items:center; font-size:24px;
    border-radius:12px; background:#EEF2FF; border:1px solid #E0E7FF;
  }
  
  .onb-title{
    font-size:18px; font-weight:700; color:#0F172A; margin-bottom:6px;
  }
  
  .onb-text{
    color: var(--ink-3); font-size:14px; max-width:720px;
    margin: 0 auto 14px; line-height:1.6;
  }
  
  .onb-actions{
    display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:6px; margin-bottom:0;
  }
  /* ukloni dodatne unutrašnje margine na ivicama bubble-a */
  .onb-card > :first-child{ margin-top:0; }
  .onb-card > :last-child{ margin-bottom:0; }
  
  .btn-xl{ padding:12px 18px; font-size:15px; }
  
  .onb-tip{
    display:flex; flex-direction:column; gap:4px;
    max-width:820px; margin: 0 auto;
    background:#F8FAFF; border:1px solid #DBEAFE; color:#1E3A8A;
    padding:10px 12px; border-radius:10px;
    text-align: left;
  }
  .onb-tip strong{ display:block; font-size:13.5px; }
  .onb-tip span{ font-size:13px; color:#475569; }
  
  /* mali ulazni efekat */
  .onb-tip-show{ animation: onbTipIn .2s ease-out; }
  @keyframes onbTipIn{
    from{ opacity:0; transform: translateY(4px); }
    to{ opacity:1; transform: translateY(0); }
  }
  

  /* kada je onboarding aktivan, grid se ponaša kao blok pa kartica ide preko cele širine */
.projects-grid.onboarding{ display:block; margin-top:0; }

/* onboarding kartica već ima padding po var(--gutter), pa vizuelno prati header */
.onb-card{
  border:1px solid var(--line);
  border-radius: var(--r-4);
  background: linear-gradient(180deg,#FFFFFF 0%, #FAFBFF 100%);
  box-shadow: var(--sh-1);
  padding: 22px var(--gutter);
  text-align: center;
}

.onb-icon{
  width:48px; height:48px; margin: 0 auto 8px;
  display:grid; place-items:center; font-size:24px;
  border-radius:12px; background:#EEF2FF; border:1px solid #E0E7FF;
}

.onb-title{ font-size:18px; font-weight:700; color:#0F172A; margin-bottom:6px; }
.onb-text{ color: var(--ink-3); font-size:14px; max-width:720px; margin: 0 auto 14px; line-height:1.6; }
.onb-actions{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:6px; margin-bottom:0; }
.onb-card > :first-child{ margin-top:0; }
.onb-card > :last-child{ margin-bottom:0; }
.btn-xl{ padding:12px 18px; font-size:15px; }

.onb-tip{
  display:flex; flex-direction:column; gap:4px;
  max-width:820px; margin: 0 auto;
  background:#F8FAFF; border:1px solid #DBEAFE; color:#1E3A8A;
  padding:10px 12px; border-radius:10px;
  text-align: left;
}
.onb-tip strong{ display:block; font-size:13.5px; }
.onb-tip span{ font-size:13px; color:#475569; }
.onb-tip-show{ animation: onbTipIn .2s ease-out; }
@keyframes onbTipIn{ from{ opacity:0; transform: translateY(4px); } to{ opacity:1; transform: translateY(0); } }
