/* DreamServer Nextcloud control panel preview (1:1 with the real client-area panel).
   Classes mirror modules/servers/nextcloud/templates/*.tpl so the layout and
   colors match what the customer actually sees in WHMCS. A small wrapper
   (.ds-cp-frame) adds a fake browser chrome around it. */

.ds-cp-frame{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 25px 60px -15px rgba(15,23,42,.25);border:1px solid #e2e8f0}
.ds-cp-chrome{background:#e2e8f0;padding:10px 14px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #cbd5e1}
.ds-cp-dots{display:flex;gap:6px;flex-shrink:0}
.ds-cp-dots span{width:12px;height:12px;border-radius:50%}
.ds-cp-dots span:nth-child(1){background:#ef4444}
.ds-cp-dots span:nth-child(2){background:#f59e0b}
.ds-cp-dots span:nth-child(3){background:#22c55e}
.ds-cp-urlbar{flex:1;min-width:0;background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:5px 12px;font-size:12px;color:#64748b;font-family:ui-monospace,Menlo,monospace;display:flex;align-items:center;gap:6px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.ds-cp-urlbar svg{flex-shrink:0;color:#22c55e}
.ds-cp-body{background:#f8fafc;padding:24px;font-family:-apple-system,Segoe UI,Roboto,sans-serif}
@media (max-width:640px){.ds-cp-body{padding:14px 10px}}

/* Nextcloud tab nav, copied verbatim from the real WHMCS module */
.nc-wrap{font-family:-apple-system,Segoe UI,Roboto,sans-serif}
.nc-nav{display:flex;gap:6px;margin-bottom:22px;border-bottom:2px solid #0082c9;padding-bottom:0;flex-wrap:wrap}
.nc-nav button{padding:10px 18px;text-decoration:none;color:#555;border-radius:6px 6px 0 0;font-weight:500;font-size:14px;background:transparent;border:0;font-family:inherit;cursor:pointer}
.nc-nav button.active{background:#0082c9;color:#fff}
.nc-nav button:hover:not(.active){background:#f0f0f0}
.nc-nav .nc-spacer{flex:1}
.nc-nav a.open{background:#28a745;color:#fff;padding:10px 18px;text-decoration:none;border-radius:6px 6px 0 0;font-weight:500;font-size:14px}
.nc-nav a.open:hover{background:#218838;color:#fff;text-decoration:none}

.nc-hero{background:linear-gradient(135deg,#0082c9 0%,#00acc1 100%);color:#fff;padding:24px 28px;border-radius:12px;margin-bottom:22px;box-shadow:0 4px 12px rgba(0,130,201,.2)}
.nc-hero.with-count{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.nc-hero-info h2{margin:0 0 6px 0;font-size:22px;font-weight:600;display:flex;align-items:center;gap:10px;color:#fff}
.nc-hero-info p{margin:0;opacity:.92;font-size:14px;max-width:560px;line-height:1.5;color:#fff}
.nc-hero-buttons{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.nc-hero-btn{padding:8px 16px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:13px;font-weight:500;text-decoration:none;cursor:default;display:inline-flex;align-items:center;gap:6px}
.nc-hero-btn:hover{background:rgba(255,255,255,.28);color:#fff;text-decoration:none}
.nc-hero-count{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);padding:14px 22px;border-radius:10px;text-align:center;min-width:130px}
.nc-hero-count .num{font-size:32px;font-weight:700;line-height:1}
.nc-hero-count .num small{font-size:18px;font-weight:500;opacity:.8}
.nc-hero-count .lbl{font-size:11px;text-transform:uppercase;opacity:.85;letter-spacing:.6px;margin-top:6px}

.nc-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:18px}
.nc-stat{background:#fff;border:1px solid #e8eaed;border-radius:10px;padding:18px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.nc-stat-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.nc-stat-label{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.nc-stat-icon{font-size:18px;opacity:.65}
.nc-stat-value{font-size:26px;font-weight:700;color:#0082c9;line-height:1}
.nc-stat-value small{font-size:14px;color:#666;font-weight:500}
.nc-stat-sub{font-size:12px;color:#777;margin-top:6px}
.nc-bar{height:6px;background:#e8eaed;border-radius:3px;overflow:hidden;margin-top:10px}
.nc-bar>span{display:block;height:100%;background:linear-gradient(90deg,#28a745,#0082c9);border-radius:3px}
.nc-bar.warn>span{background:linear-gradient(90deg,#ffc107,#ff9800)}
.nc-bar.danger>span{background:linear-gradient(90deg,#dc3545,#c82333)}

.nc-card{background:#fff;border:1px solid #e8eaed;border-radius:10px;padding:20px;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.nc-card h3{margin:0 0 12px;font-size:15px;color:#0082c9;font-weight:600;display:flex;align-items:center;gap:8px}
.nc-card-desc{font-size:13px;color:#666;margin:0 0 14px;line-height:1.5}

.nc-quick{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.nc-quick a{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#f8f9fa;border:1px solid #e8eaed;border-radius:8px;text-decoration:none;color:#333;cursor:default;transition:background .15s,border-color .15s}
.nc-quick a:hover{background:#eef7ff;border-color:#d4e7f5}
.nc-quick .ic{font-size:20px}
.nc-quick .lbl{font-size:13px;font-weight:600;color:#0082c9;display:block}
.nc-quick .desc{font-size:11px;color:#777;display:block;margin-top:2px}

.nc-cred{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#f8f9fa;border:1px solid #e8eaed;border-radius:8px;margin-bottom:8px;flex-wrap:wrap}
.nc-cred-label{flex:0 0 130px;font-size:11px;color:#666;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.nc-cred-value{flex:1;min-width:0;font-family:ui-monospace,Menlo,monospace;font-size:13px;color:#222;word-break:break-all}
.nc-cred-actions{display:flex;gap:6px;flex-shrink:0}
.nc-mini{padding:5px 10px;font-size:12px;border:1px solid #d6d6d6;border-radius:4px;background:#fff;cursor:pointer;color:#444;font-family:inherit}
.nc-mini:hover{background:#0082c9;color:#fff;border-color:#0082c9}
.nc-mini.copied{background:#28a745;color:#fff;border-color:#28a745}
.nc-tip{margin-top:10px;padding:10px 12px;background:#eef7ff;border-left:3px solid #0082c9;border-radius:4px;font-size:12px;color:#0c5e91;line-height:1.5}

.nc-2fa{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;background:#fff;border:1px dashed #d4e7f5;border-radius:8px;margin-top:10px}
.nc-2fa-text{font-size:12px;color:#555}
.nc-2fa-link{font-size:12px;color:#0082c9;font-weight:600;text-decoration:none}

.nc-mini-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:6px}
.nc-mini-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px}
.nc-mini-table th,.nc-mini-table td{text-align:left;padding:8px 10px;border-bottom:1px solid #f0f0f0}
.nc-mini-table th{font-weight:600;color:#666;text-transform:uppercase;font-size:11px;letter-spacing:.4px;background:#f8f9fa}
.nc-mini-table tr:last-child td{border-bottom:0}
.nc-mini-table code{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:#0066a3;background:transparent;padding:0}
@media(max-width:640px){.nc-mini-table-wrap .nc-mini-table{min-width:480px}.nc-mini-table th,.nc-mini-table td{white-space:nowrap}}

.nc-badge{display:inline-block;padding:3px 10px;border-radius:11px;font-size:11px;font-weight:600;white-space:nowrap}
.nc-badge.ok{background:#d4edda;color:#155724}
.nc-badge.susp{background:#f8d7da;color:#721c24}

.nc-account-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.nc-account-info-item .lbl{font-size:11px;text-transform:uppercase;color:#888;letter-spacing:.6px;font-weight:600;margin-bottom:4px}
.nc-account-info-item .val{font-family:ui-monospace,Menlo,monospace;font-size:13px;color:#222;word-break:break-all}
.nc-account-info-item .val.regular{font-family:inherit;font-size:13px}

/* Sub-users tab */
.nc-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.nc-form .full{grid-column:1/-1}
.nc-form label{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:.6px;display:block;margin-bottom:6px;font-weight:600}
.nc-form input,.nc-form select{width:100%;padding:9px 12px;border:1px solid #d6d6d6;border-radius:6px;font-size:14px;box-sizing:border-box;font-family:inherit;cursor:default}
.nc-form input:focus,.nc-form select:focus{outline:none;border-color:#0082c9;box-shadow:0 0 0 3px rgba(0,130,201,.12)}
.nc-form small{font-size:11px;color:#888;display:block;margin-top:4px}
.nc-submit{background:#0082c9;color:#fff;padding:10px 24px;border:0;border-radius:6px;cursor:pointer;font-weight:600;font-size:14px;font-family:inherit}
.nc-submit:hover{background:#006aa3}

details.nc-collapsible{background:#fff;border:1px solid #e8eaed;border-radius:10px;margin-bottom:18px;box-shadow:0 1px 3px rgba(0,0,0,.04);overflow:hidden}
details.nc-collapsible[open]{box-shadow:0 4px 12px rgba(0,0,0,.06)}
details.nc-collapsible summary{list-style:none;cursor:pointer;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#0082c9;font-size:15px;user-select:none}
details.nc-collapsible summary::-webkit-details-marker{display:none}
details.nc-collapsible summary::after{content:'+';font-size:22px;color:#888;font-weight:300}
details.nc-collapsible[open] summary::after{transform:rotate(45deg)}
details.nc-collapsible[open] summary{border-bottom:1px solid #f0f0f0}
details.nc-collapsible summary:hover{background:#f8f9fa}
details.nc-collapsible .nc-collapsible-body{padding:20px}

.nc-user-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.nc-user{background:#fff;border:1px solid #e8eaed;border-radius:10px;padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.nc-user.disabled{opacity:.65;background:#fafafa}
.nc-user-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.nc-user-id{font-family:ui-monospace,Menlo,monospace;font-size:13px;font-weight:600;color:#0082c9;word-break:break-all;line-height:1.3}
.nc-user-name{font-size:14px;color:#222;font-weight:500;margin-top:4px;line-height:1.3}
.nc-user-meta{font-size:12px;color:#666;margin-top:4px;display:flex;align-items:center;gap:6px;line-height:1.4}
.nc-user-meta-icon{color:#999;font-size:11px;flex-shrink:0}
.nc-user-chips{display:flex;flex-wrap:wrap;gap:5px}
.nc-chip{display:inline-block;background:#eef7ff;color:#0066a3;padding:3px 9px;border-radius:11px;font-size:11px;font-weight:500;border:1px solid #d4e7f5}
.nc-storage{padding:10px 12px;background:#f8f9fa;border-radius:6px;border:1px solid #f0f0f0}
.nc-storage-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#555;margin-bottom:6px}
.nc-storage-row strong{color:#222;font-weight:600;font-family:ui-monospace,Menlo,monospace;font-size:11px}
.nc-user-last{font-size:11px;color:#888;display:flex;align-items:center;gap:6px}
.nc-user-actions{display:flex;gap:6px;flex-wrap:wrap;border-top:1px solid #f0f0f0;padding-top:12px;margin-top:auto}
.nc-btn-ic{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:0;cursor:pointer;color:#fff;font-size:15px;padding:0;font-family:inherit}
.nc-btn-ic.reset{background:#ffc107;color:#5b3e00}
.nc-btn-ic.disable{background:#6c757d}
.nc-btn-ic.delete{background:#dc3545}
.nc-btn-ic.groups{background:#0082c9}

.nc-group-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.nc-group{background:#fff;border:1px solid #e8eaed;border-radius:10px;padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.nc-group-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.nc-group-name{font-size:15px;font-weight:600;color:#0082c9;display:flex;align-items:center;gap:8px;line-height:1.3;flex:1;min-width:0}
.nc-group-count{background:#eef7ff;color:#0066a3;border:1px solid #d4e7f5;padding:3px 10px;border-radius:11px;font-size:11px;font-weight:600;white-space:nowrap}
.nc-members-block{padding:10px 12px;background:#f8f9fa;border-radius:6px;border:1px solid #f0f0f0}
.nc-members-label{font-size:11px;text-transform:uppercase;color:#666;letter-spacing:.5px;font-weight:600;margin-bottom:8px}
.nc-member-chips{display:flex;flex-wrap:wrap;gap:5px}
.nc-member{display:inline-block;background:#fff;color:#444;border:1px solid #ddd;padding:3px 9px;border-radius:11px;font-size:11px;font-family:ui-monospace,Menlo,monospace;font-weight:500}

/* Settings tab */
.nc-settings-narrow{max-width:780px;margin:0 auto}
.nc-identity{background:#fff;border:1px solid #e8eaed;border-radius:10px;padding:18px 20px;margin-bottom:18px;box-shadow:0 1px 3px rgba(0,0,0,.04);display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.nc-card-stack .nc-card-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.nc-card-stack .nc-card-head h3{margin:0;font-size:16px;color:#0082c9;font-weight:600}
.nc-card-stack .nc-card-head .ic{font-size:20px}
.nc-card-stack form .nc-form{grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:520px){.nc-card-stack form .nc-form{grid-template-columns:1fr}}
.nc-pw-wrap{position:relative}
.nc-pw-wrap input{padding-right:60px}
.nc-pw-wrap .pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:0;cursor:pointer;color:#888;font-size:12px;padding:4px 8px;border-radius:4px;font-family:inherit}
.nc-pw-wrap .pw-toggle:hover{background:#f0f0f0;color:#222}
.nc-form-actions{text-align:right;border-top:1px solid #f0f0f0;padding-top:14px;margin-top:6px}

@media (max-width:600px){
  .nc-hero.with-count{flex-direction:column;align-items:flex-start;padding:20px}
  .nc-hero-count{align-self:stretch}
  .nc-cred-label{flex:0 0 100%;margin-bottom:4px}
}

/* Tab pane fade-in */
.nc-pane{display:none}
.nc-pane.active{display:block;animation:ncFadeIn .2s ease-out}
@keyframes ncFadeIn{from{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:none}}
