/* ===================================================
   LinkFolio — Main Stylesheet
   Import in your layout: <link rel="stylesheet" href="{{ asset('css/app.css') }}">
   =================================================== */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

:root {
    --bg:    #0c0c0c;
    --bg2:   #141414;
    --bg3:   #1c1c1c;
    --card:  #111111;
    --red:   #e8192c;
    --red2:  #ff4d5e;
    --red3:  #ff8a93;
    --white: #f5f5f5;
    --muted: #666666;
    --bdr:   rgba(255,255,255,0.07);
    --rbdr:  rgba(232,25,44,0.22);
    --glow:  0 0 60px rgba(232,25,44,0.18);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: 'Poppins', sans-serif;
    background: var(--bg);
    color: var(--white);
    min-height: 100vh;
    overflow-x: hidden;
}

/* ── Orbs ────────────────────────────────────────── */
.bg-orbs { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.orb     { position: absolute; border-radius: 50%; filter: blur(90px); }
.o1 { width:520px; height:520px; background:var(--red);  opacity:.16; top:-180px; left:-140px; animation:d1 14s ease-in-out infinite; }
.o2 { width:420px; height:420px; background:#cc1020;     opacity:.13; bottom:-100px; right:-120px; animation:d2 18s ease-in-out infinite; }
.o3 { width:280px; height:280px; background:#ff3344;     opacity:.09; top:42%; left:38%; animation:d3 11s ease-in-out infinite; }
.o4 { width:180px; height:180px; background:#fff;        opacity:.025; top:18%; right:18%; animation:d4 9s ease-in-out infinite; }

@keyframes d1 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(55px,40px) scale(1.07)} }
@keyframes d2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-45px,-55px)} }
@keyframes d3 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(28px,-28px)} }
@keyframes d4 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-18px,18px)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes spin   { to{transform:rotate(360deg)} }
@keyframes pulse  { 0%,100%{opacity:1} 50%{opacity:.35} }

/* ── Profile page ────────────────────────────────── */
.profile-wrap {
    position: relative; z-index: 1;
    width: 100%; max-width: 430px;
    margin: 58px auto 0;
    padding: 0 16px 90px;
    animation: fadeUp .65s ease both;
}

.avatar-ring {
    width:90px; height:90px; margin:0 auto 16px; border-radius:50%; padding:3px;
    background: conic-gradient(from 0deg,var(--red),#fff 35%,var(--red2) 65%,#fff 82%,var(--red));
    position:relative; animation:spin 6s linear infinite;
}
.avatar-inner {
    width:100%; height:100%; border-radius:50%; background:var(--bg);
    display:flex; align-items:center; justify-content:center;
    font-size:30px; font-weight:800; color:var(--red);
    animation:spin 6s linear infinite reverse;
}
.online-dot {
    position:absolute; bottom:4px; right:4px;
    width:13px; height:13px; border-radius:50%;
    background:#22c55e; border:2.5px solid var(--bg);
    animation:pulse 2s ease-in-out infinite;
}

.pf-name   { font-size:24px; font-weight:800; text-align:center; letter-spacing:-.5px; background:linear-gradient(90deg,var(--white) 0%,var(--red2) 55%,var(--red) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.pf-handle { text-align:center; color:var(--muted); font-size:13px; font-weight:400; margin-top:3px; }
.pf-bio    { text-align:center; font-size:13px; color:rgba(245,245,245,.58); margin:12px 0 26px; line-height:1.7; font-weight:300; }

.links-section { width:100%; display:flex; flex-direction:column; gap:11px; }

.link-btn {
    width:100%; background:var(--card); border:1px solid var(--bdr);
    border-radius:16px; padding:15px 18px; display:flex; align-items:center; gap:13px;
    cursor:pointer; color:var(--white); position:relative; overflow:hidden;
    transition:transform .15s,border-color .22s,box-shadow .22s;
    animation:fadeUp .6s ease both; text-align:left; text-decoration:none;
}
.link-btn::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,var(--red),var(--red2)); opacity:0; transition:opacity .25s; }
.link-btn:hover  { transform:translateY(-2px); border-color:var(--rbdr); box-shadow:0 6px 28px rgba(232,25,44,.2); }
.link-btn:hover::after { opacity:.07; }
.link-btn:active { transform:scale(.976); }

.btn-ico { width:44px; height:44px; border-radius:12px; background:linear-gradient(135deg,var(--red),var(--red2)); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; position:relative; z-index:1; box-shadow:0 4px 16px rgba(232,25,44,.32); }
.btn-cnt { flex:1; position:relative; z-index:1; min-width:0; }
.btn-t   { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.btn-s   { font-size:11px; color:var(--muted); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.btn-arr { position:relative; z-index:1; color:var(--muted); font-size:16px; flex-shrink:0; }

.fab-wrap { position:fixed; bottom:22px; right:22px; z-index:100; }
.fab { width:48px; height:48px; border-radius:50%; border:none; background:linear-gradient(135deg,var(--red),var(--red2)); color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:20px; box-shadow:0 4px 22px rgba(232,25,44,.55); transition:transform .2s,box-shadow .2s; text-decoration:none; }
.fab:hover { transform:scale(1.12) rotate(15deg); box-shadow:0 6px 32px rgba(232,25,44,.75); }

/* ── Login page ──────────────────────────────────── */
.login-wrap { display:flex; align-items:center; justify-content:center; min-height:100vh; padding:20px; position:relative; }
.login-card { position:relative; z-index:1; background:var(--card); border:1px solid var(--bdr); border-radius:24px; padding:40px 36px; width:100%; max-width:380px; box-shadow:var(--glow); animation:fadeUp .5s ease; }
.lg-logo { font-size:20px; font-weight:800; text-align:center; background:linear-gradient(90deg,var(--white),var(--red)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; margin-bottom:5px; }
.lg-sub  { text-align:center; color:var(--muted); font-size:12px; margin-bottom:28px; font-weight:400; }

.fg  { margin-bottom:15px; }
.fl  { font-size:10px; color:var(--muted); letter-spacing:.8px; margin-bottom:6px; display:block; font-weight:600; text-transform:uppercase; }
.fi  { width:100%; background:var(--bg3); border:1px solid var(--bdr); border-radius:11px; padding:12px 15px; font-family:'Poppins',sans-serif; font-size:13px; font-weight:400; color:var(--white); outline:none; transition:border-color .2s,box-shadow .2s; }
.fi:focus { border-color:var(--red); box-shadow:0 0 0 3px rgba(232,25,44,.12); }
.fi::placeholder { color:var(--muted); }
.fi.is-invalid { border-color:#ff6060; }

.btn-p { width:100%; background:linear-gradient(135deg,var(--red),var(--red2)); border:none; border-radius:12px; padding:13px; font-family:'Poppins',sans-serif; font-size:13px; font-weight:700; color:#fff; cursor:pointer; transition:transform .15s,box-shadow .2s; box-shadow:0 4px 20px rgba(232,25,44,.4); margin-top:6px; }
.btn-p:hover  { transform:translateY(-1px); box-shadow:0 6px 28px rgba(232,25,44,.62); }
.btn-p:active { transform:scale(.98); }

.err-msg  { color:#ff6060; font-size:11px; margin-top:6px; font-weight:500; }
.back-lnk { text-align:center; margin-top:18px; font-size:12px; color:var(--muted); }
.back-lnk a { color:var(--red2); text-decoration:none; font-weight:500; }
.hint-bx  { background:rgba(232,25,44,.07); border:1px solid rgba(232,25,44,.18); border-radius:10px; padding:10px 14px; margin-top:16px; font-size:11px; color:var(--muted); line-height:1.65; }

/* ── Dashboard nav ───────────────────────────────── */
.d-nav  { background:rgba(17,17,17,.9); border-bottom:1px solid var(--bdr); padding:13px 22px; display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; z-index:50; backdrop-filter:blur(14px); }
.d-logo { font-size:17px; font-weight:800; background:linear-gradient(90deg,var(--white),var(--red)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.nav-r  { display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.nb { background:none; border:1px solid var(--bdr); border-radius:8px; color:var(--muted); font-family:'Poppins',sans-serif; font-size:11px; font-weight:500; padding:6px 12px; cursor:pointer; transition:all .2s; text-decoration:none; }
.nb:hover { border-color:var(--rbdr); color:var(--red2); }
.nb.on    { background:rgba(232,25,44,.12); border-color:var(--rbdr); color:var(--red2); }

.d-body   { flex:1; padding:26px 22px; max-width:920px; width:100%; margin:0 auto; }
.sec-ttl  { font-size:20px; font-weight:800; margin-bottom:3px; }
.sec-sub  { font-size:12px; color:var(--muted); margin-bottom:24px; font-weight:400; }
.live-dot { display:inline-block; width:7px; height:7px; border-radius:50%; background:#22c55e; margin-right:4px; animation:pulse 2s ease-in-out infinite; }

.tab-pnl    { display:none; }
.tab-pnl.on { display:block; }

/* ── Metric cards ────────────────────────────────── */
.mg { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:13px; margin-bottom:24px; }
.mc { background:var(--card); border:1px solid var(--bdr); border-radius:16px; padding:20px 17px; position:relative; overflow:hidden; transition:transform .2s,box-shadow .2s; }
.mc::before { content:''; position:absolute; top:-20px; right:-20px; width:80px; height:80px; border-radius:50%; background:var(--red); opacity:.06; }
.mc:hover { transform:translateY(-2px); box-shadow:0 8px 26px rgba(0,0,0,.45); }
.mc-ic { font-size:20px; margin-bottom:9px; }
.mc-v  { font-size:28px; font-weight:800; background:linear-gradient(90deg,var(--white),var(--red2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.mc-l  { font-size:11px; color:var(--muted); margin-top:5px; font-weight:400; }
.mc-n  { font-size:10px; margin-top:5px; color:#22c55e; font-weight:500; }

/* ── Charts ──────────────────────────────────────── */
.ch-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:18px; }
@media(max-width:560px){ .ch-row { grid-template-columns:1fr; } }
.cc   { background:var(--card); border:1px solid var(--bdr); border-radius:16px; padding:20px; }
.cc-t { font-size:13px; font-weight:700; margin-bottom:15px; }

.bar-ch { display:flex; flex-direction:column; gap:9px; }
.brow  { display:flex; align-items:center; gap:8px; }
.blbl  { font-size:11px; color:var(--muted); width:84px; text-align:right; flex-shrink:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.btrk  { flex:1; height:9px; background:var(--bg3); border-radius:99px; overflow:hidden; }
.bfil  { height:100%; border-radius:99px; background:linear-gradient(90deg,var(--red),var(--red2)); transition:width 1.1s cubic-bezier(.23,1,.32,1); }
.bval  { font-size:11px; font-weight:700; width:28px; text-align:right; flex-shrink:0; }

.dn-wrap { display:flex; align-items:center; gap:18px; }
.dn-leg  { display:flex; flex-direction:column; gap:8px; flex:1; }
.lg-it   { display:flex; align-items:center; gap:7px; font-size:11px; }
.lg-dt   { width:9px; height:9px; border-radius:50%; flex-shrink:0; }

.sp-card { background:var(--card); border:1px solid var(--bdr); border-radius:16px; padding:20px; margin-bottom:18px; }
.sp-svg  { width:100%; height:90px; }

/* ── Table ───────────────────────────────────────── */
.tc     { background:var(--card); border:1px solid var(--bdr); border-radius:16px; overflow:hidden; margin-bottom:18px; }
.tc-top { padding:14px 20px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--bdr); }
.tc-ttl { font-size:13px; font-weight:700; }

.btn-dng { background:rgba(232,25,44,.1); border:1px solid rgba(232,25,44,.25); border-radius:8px; color:var(--red2); font-family:'Poppins',sans-serif; font-size:11px; font-weight:600; padding:6px 12px; cursor:pointer; transition:all .2s; }
.btn-dng:hover { background:rgba(232,25,44,.2); }

.trow   { display:grid; grid-template-columns:1fr 68px 58px 106px 88px; padding:12px 20px; align-items:center; border-bottom:1px solid rgba(255,255,255,.03); transition:background .15s; gap:8px; }
.trow:hover { background:rgba(255,255,255,.02); }
.trow.th { color:var(--muted); font-size:10px; font-weight:600; letter-spacing:.7px; padding:9px 20px; background:var(--bg3); text-transform:uppercase; }
.tcl    { font-size:12px; }
.tcl.r  { text-align:right; }
.tcl.b  { font-weight:700; }
.bn-c   { display:flex; align-items:center; gap:8px; }
.bn-d   { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.pb     { height:4px; background:var(--bg3); border-radius:99px; overflow:hidden; margin-top:4px; }
.pf     { height:100%; border-radius:99px; }

.tag    { display:inline-flex; align-items:center; font-size:9px; font-weight:700; letter-spacing:.3px; padding:3px 7px; border-radius:20px; }
.tg-u   { background:rgba(34,197,94,.12); color:#22c55e; }
.tg-n   { background:rgba(100,100,100,.1); color:var(--muted); }

/* ── Activity ────────────────────────────────────── */
.ac-list { display:flex; flex-direction:column; }
.ac-it   { display:flex; align-items:center; gap:11px; padding:11px 20px; border-bottom:1px solid rgba(255,255,255,.03); font-size:12px; transition:background .15s; }
.ac-it:hover { background:rgba(255,255,255,.02); }
.ac-ico  { width:30px; height:30px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
.ac-inf  { flex:1; }
.ac-nm   { font-weight:600; font-size:12px; }
.ac-tm   { font-size:10px; color:var(--muted); margin-top:1px; }
.ac-ct   { font-weight:800; font-size:15px; }

/* ── Button Manager ──────────────────────────────── */
.mn-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:13px; margin-bottom:24px; }
.mn-card { background:var(--card); border:1px solid var(--bdr); border-radius:16px; padding:17px; position:relative; transition:border-color .2s,box-shadow .2s; }
.mn-card:hover { border-color:var(--rbdr); box-shadow:0 4px 22px rgba(232,25,44,.12); }
.mn-ic   { font-size:24px; margin-bottom:10px; }
.mn-nm   { font-size:13px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mn-sb   { font-size:11px; color:var(--muted); margin-top:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-weight:400; }
.mn-acts { display:flex; gap:7px; margin-top:13px; }
.mn-b    { flex:1; background:var(--bg3); border:1px solid var(--bdr); border-radius:8px; color:var(--muted); font-family:'Poppins',sans-serif; font-size:10px; font-weight:600; padding:6px 0; cursor:pointer; transition:all .2s; text-transform:uppercase; letter-spacing:.4px; }
.mn-b:hover     { border-color:var(--rbdr); color:var(--red2); background:rgba(232,25,44,.08); }
.mn-b.del:hover { border-color:rgba(232,25,44,.6); color:var(--red); background:rgba(232,25,44,.12); }
.mn-clk  { position:absolute; top:14px; right:14px; font-size:10px; font-weight:700; background:rgba(232,25,44,.12); color:var(--red2); padding:3px 8px; border-radius:20px; }

.add-card { background:none; border:2px dashed rgba(255,255,255,.09); border-radius:16px; padding:17px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; cursor:pointer; min-height:132px; transition:border-color .2s,background .2s; color:var(--muted); font-family:'Poppins',sans-serif; font-size:12px; font-weight:500; width:100%; }
.add-card:hover { border-color:var(--rbdr); background:rgba(232,25,44,.04); color:var(--red2); }
.add-ic  { font-size:28px; }

/* ── Modal ───────────────────────────────────────── */
.m-ov  { position:fixed; inset:0; background:rgba(0,0,0,.78); backdrop-filter:blur(7px); z-index:200; display:none; align-items:center; justify-content:center; padding:20px; }
.m-ov.open { display:flex; }
.modal { background:var(--bg2); border:1px solid var(--bdr); border-radius:22px; padding:32px 28px; width:100%; max-width:400px; animation:fadeUp .3s ease; box-shadow:0 20px 60px rgba(0,0,0,.65); }
.m-ttl { font-size:17px; font-weight:800; margin-bottom:4px; }
.m-sub2 { font-size:12px; color:var(--muted); margin-bottom:22px; font-weight:400; }
.m-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.m-acts { display:flex; gap:10px; margin-top:20px; }
.btn-can { flex:1; background:var(--bg3); border:1px solid var(--bdr); border-radius:11px; color:var(--muted); font-family:'Poppins',sans-serif; font-size:13px; font-weight:600; padding:12px; cursor:pointer; transition:all .2s; }
.btn-can:hover { color:var(--white); border-color:rgba(255,255,255,.14); }
.btn-sv  { flex:2; background:linear-gradient(135deg,var(--red),var(--red2)); border:none; border-radius:11px; color:#fff; font-family:'Poppins',sans-serif; font-size:13px; font-weight:700; padding:12px; cursor:pointer; box-shadow:0 4px 16px rgba(232,25,44,.4); transition:transform .15s,box-shadow .2s; }
.btn-sv:hover { transform:translateY(-1px); box-shadow:0 6px 24px rgba(232,25,44,.62); }

.prev-row { display:flex; align-items:center; gap:12px; background:var(--bg3); border:1px solid var(--bdr); border-radius:13px; padding:13px 16px; margin-bottom:16px; }
.prev-ic  { width:40px; height:40px; border-radius:11px; background:linear-gradient(135deg,var(--red),var(--red2)); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.prev-tt  { font-size:13px; font-weight:600; }
.prev-sb  { font-size:11px; color:var(--muted); margin-top:2px; }

/* ── Toast ───────────────────────────────────────── */
.toast { position:fixed; bottom:80px; left:50%; transform:translateX(-50%) translateY(16px); background:var(--card); border:1px solid var(--bdr); border-radius:12px; padding:11px 22px; font-size:12px; font-weight:600; opacity:0; pointer-events:none; transition:all .3s; z-index:999; white-space:nowrap; box-shadow:0 4px 20px rgba(0,0,0,.5); }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.gr   { border-color:rgba(34,197,94,.3); color:#22c55e; }
.toast.rd   { border-color:rgba(232,25,44,.4); color:var(--red2); }

.empty { padding:36px; text-align:center; color:var(--muted); font-size:12px; }
