@import url('https://fonts.googleapis.com/css2?family=Titillium+Web:wght@400;600;700;800&display=swap');
:root{--bg:#09090b;--panel:#121217;--panel2:#191922;--text:#f7f7fb;--muted:#a8a8b5;--red:#ef233c;--red2:#b80f24;--line:rgba(255,255,255,.09);--ok:#24d17e;--warn:#ffd166}*{box-sizing:border-box}body{margin:0;font-family:'Titillium Web',system-ui,sans-serif;background:radial-gradient(circle at 20% 0%,rgba(239,35,60,.22),transparent 34%),linear-gradient(135deg,#050507,#101018 48%,#09090b);color:var(--text);min-height:100vh}a{color:inherit}.wrap{max-width:1180px;margin:0 auto;padding:28px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px}.brand{font-size:25px;font-weight:800;letter-spacing:-.03em}.brand span{color:var(--red)}.nav{display:flex;gap:10px;flex-wrap:wrap}.btn,.button,button,input[type=submit]{border:0;border-radius:14px;background:linear-gradient(135deg,var(--red),var(--red2));color:white;padding:11px 16px;font-weight:800;text-decoration:none;cursor:pointer;box-shadow:0 14px 34px rgba(239,35,60,.22);font-family:inherit}.btn.secondary{background:#242430;box-shadow:none}.btn.ghost{background:transparent;border:1px solid var(--line);box-shadow:none}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}.card{grid-column:span 12;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border:1px solid var(--line);border-radius:26px;padding:22px;box-shadow:0 20px 70px rgba(0,0,0,.25);backdrop-filter:blur(18px)}.half{grid-column:span 6}.third{grid-column:span 4}.two-third{grid-column:span 8}h1,h2,h3{margin:0 0 12px;line-height:.98;letter-spacing:-.04em}h1{font-size:52px}h2{font-size:31px}.muted{color:var(--muted)}label{display:block;font-weight:700;margin:12px 0 6px}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:#0e0e14;color:var(--text);padding:12px 13px;font-family:inherit;font-size:15px}textarea{min-height:86px}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;border-bottom:1px solid var(--line);text-align:left}.pill{display:inline-flex;border:1px solid var(--line);border-radius:999px;padding:5px 10px;color:var(--muted);font-size:13px}.metric{font-size:38px;font-weight:800}.login{max-width:430px;margin:9vh auto}.notice{border:1px solid rgba(36,209,126,.35);background:rgba(36,209,126,.1);border-radius:14px;padding:12px;margin-bottom:15px}.danger{color:#ff7b89}.links-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.public-shell{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:25px}.smart-card{width:100%;max-width:510px;text-align:center;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));border:1px solid var(--line);border-radius:34px;padding:28px;box-shadow:0 35px 100px rgba(0,0,0,.45)}.cover{width:220px;height:220px;object-fit:cover;border-radius:28px;box-shadow:0 20px 55px rgba(0,0,0,.42);margin:0 auto 22px;display:block;background:#222}.smart-title{font-size:44px;font-weight:800;line-height:.92;letter-spacing:-.05em;margin-bottom:6px}.smart-artist{font-size:20px;color:var(--muted);margin-bottom:20px}.platform-btn{display:flex;justify-content:space-between;align-items:center;width:100%;border-radius:18px;padding:15px 17px;margin:10px 0;background:#fff;color:#111;text-decoration:none;font-weight:800}.platform-btn small{opacity:.55}.platform-spotify{background:#1DB954;color:#07100a}.platform-apple{background:#fff;color:#111}.platform-youtube{background:#ff0033;color:#fff}.platform-amazon{background:#28a6df;color:#071018}.platform-deezer{background:#a238ff;color:#fff}.footer-note{font-size:12px;color:var(--muted);margin-top:18px}.copybox{font-family:ui-monospace,Menlo,monospace;background:#060609;border:1px solid var(--line);border-radius:14px;padding:12px;word-break:break-all;color:#d7d7e0}@media(max-width:780px){.wrap{padding:18px}.half,.third,.two-third{grid-column:span 12}.topbar{align-items:flex-start;flex-direction:column}h1{font-size:39px}.links-grid{grid-template-columns:1fr}.smart-title{font-size:35px}}

/* Phase 1.5 - Smart Link Premium */
.smart-premium-body{overflow-x:hidden;background:#060609;color:#fff}.smart-bg{position:fixed;inset:-40px;background-size:cover;background-position:center;filter:blur(34px) saturate(1.22);opacity:.38;transform:scale(1.08);z-index:-4}.smart-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 16%,rgba(255,255,255,.13),transparent 24%),linear-gradient(180deg,rgba(6,6,9,.18),rgba(6,6,9,.82) 57%,#060609)}.smart-bg-empty{background:radial-gradient(circle at 30% 0%,rgba(239,35,60,.45),transparent 36%),radial-gradient(circle at 80% 30%,rgba(255,209,102,.18),transparent 28%),#060609}.smart-orb{position:fixed;border-radius:999px;filter:blur(42px);opacity:.62;pointer-events:none;z-index:-3}.smart-orb-one{width:290px;height:290px;left:-90px;top:11%;background:rgba(239,35,60,.42)}.smart-orb-two{width:250px;height:250px;right:-80px;bottom:8%;background:rgba(255,255,255,.13)}.smart-premium-shell{padding:34px 18px;align-items:center}.smart-premium-card{width:100%;max-width:620px;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.16);border-radius:38px;background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.055));box-shadow:0 32px 110px rgba(0,0,0,.58);backdrop-filter:blur(24px);padding:22px}.smart-premium-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 28%,rgba(239,35,60,.08) 72%,rgba(255,255,255,.08));pointer-events:none}.smart-premium-hero{position:relative;z-index:1;text-align:center}.smart-cover-wrap{position:relative;width:245px;height:245px;margin:0 auto 22px}.smart-cover-wrap:before{content:"";position:absolute;inset:14px;border-radius:34px;background:rgba(239,35,60,.55);filter:blur(35px);opacity:.55}.smart-cover-premium{position:relative;width:245px;height:245px;object-fit:cover;border-radius:34px;box-shadow:0 25px 65px rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a22,#09090b);font-weight:900;font-size:48px;letter-spacing:-.06em}.smart-kicker{display:inline-flex;align-items:center;gap:8px;margin:0 auto 12px;border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:7px 13px;background:rgba(0,0,0,.24);color:#fff;font-size:12px;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.smart-kicker:before{content:"";width:7px;height:7px;border-radius:999px;background:#1DB954;box-shadow:0 0 18px rgba(29,185,84,.9)}.smart-title-premium{font-size:clamp(38px,8vw,64px);line-height:.88;margin:0 0 8px;font-weight:900;letter-spacing:-.07em;text-wrap:balance}.smart-artist-premium{font-size:22px;font-weight:700;color:rgba(255,255,255,.84);margin-bottom:7px}.smart-meta-premium{font-size:13px;font-weight:700;color:rgba(255,255,255,.54);text-transform:uppercase;letter-spacing:.12em;margin-bottom:15px}.smart-description-premium{max-width:470px;margin:0 auto 20px;color:rgba(255,255,255,.72);font-size:17px;line-height:1.35}.smart-platforms-premium{position:relative;z-index:1;display:grid;gap:11px;margin-top:18px}.platform-btn-premium{position:relative;display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:61px;padding:14px 15px 14px 14px;border-radius:21px;text-decoration:none;color:#fff;background:rgba(255,255,255,.105);border:1px solid rgba(255,255,255,.13);box-shadow:0 12px 34px rgba(0,0,0,.18);transition:transform .18s ease,border-color .18s ease,background .18s ease,box-shadow .18s ease}.platform-btn-premium:hover{transform:translateY(-2px);background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.25);box-shadow:0 18px 42px rgba(0,0,0,.26)}.platform-btn-premium.is-main{min-height:72px;background:linear-gradient(135deg,#1DB954,#13a044);color:#031108;border-color:rgba(255,255,255,.22);box-shadow:0 20px 54px rgba(29,185,84,.28)}.platform-left{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:900}.platform-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:14px;background:rgba(255,255,255,.14);font-weight:900}.platform-btn-premium.is-main .platform-icon{background:rgba(0,0,0,.12)}.platform-action{font-size:13px;font-weight:900;opacity:.72;text-transform:uppercase;letter-spacing:.08em}.platform-btn-premium.platform-apple{background:rgba(255,255,255,.94);color:#08080b}.platform-btn-premium.platform-youtube{background:linear-gradient(135deg,#ff0033,#c50024);color:#fff}.platform-btn-premium.platform-amazon{background:linear-gradient(135deg,#28a6df,#1077a7);color:#fff}.platform-btn-premium.platform-deezer{background:linear-gradient(135deg,#a238ff,#641dff);color:#fff}.platform-btn-premium.platform-tidal{background:#fff;color:#08080b}.platform-btn-premium.platform-soundcloud{background:linear-gradient(135deg,#ff8a00,#ff4d00);color:#fff}.platform-btn-premium.platform-bandcamp{background:linear-gradient(135deg,#629aa9,#3f7786);color:#fff}.smart-footer-premium{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:6px;margin-top:20px;color:rgba(255,255,255,.48);font-size:12px;letter-spacing:.04em}.smart-footer-premium strong{color:rgba(255,255,255,.78)}.smart-empty-links{position:relative;z-index:1;border:1px solid rgba(255,255,255,.14);border-radius:18px;background:rgba(0,0,0,.22);padding:14px;color:rgba(255,255,255,.68);text-align:center}@media(max-width:620px){.smart-premium-shell{padding:18px 12px}.smart-premium-card{border-radius:30px;padding:16px}.smart-cover-wrap,.smart-cover-premium{width:205px;height:205px;border-radius:28px}.smart-title-premium{font-size:clamp(34px,12vw,50px)}.smart-description-premium{font-size:15px}.platform-btn-premium{border-radius:18px}.platform-left{font-size:16px}.platform-icon{width:35px;height:35px;border-radius:12px}}

.notice{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);border-radius:18px;padding:14px 16px;margin:0 0 18px;color:#fff;box-shadow:0 18px 50px rgba(0,0,0,.18)}
.notice.success{border-color:rgba(52,211,153,.35);background:rgba(16,185,129,.12)}
.reset-stats-form{margin-top:12px}.btn.danger{background:linear-gradient(135deg,#ef4444,#991b1b);color:#fff;border-color:rgba(255,255,255,.18)}.btn.danger:hover{filter:brightness(1.08)}

/* Phase 1.7 - Fanlink Visual Redesign + reliable platform click UI */
.fanlink-body{margin:0;min-height:100vh;overflow-x:hidden;background:#07070a;color:#111;font-family:'Titillium Web',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif}.fanlink-bg{position:fixed;inset:-70px;background-size:cover;background-position:center;filter:blur(38px) saturate(1.18);transform:scale(1.12);opacity:.82;z-index:-4}.fanlink-bg-empty{background:radial-gradient(circle at 20% 10%,rgba(236,72,153,.58),transparent 34%),radial-gradient(circle at 75% 22%,rgba(99,102,241,.55),transparent 36%),#09090b}.fanlink-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.32),rgba(6,6,9,.12) 36%,rgba(6,6,9,.28) 67%,rgba(255,255,255,.24)),radial-gradient(circle at 50% 12%,rgba(255,255,255,.18),transparent 22%)}.fanlink-vignette{position:fixed;inset:0;background:radial-gradient(circle at 50% 46%,rgba(255,255,255,.05),transparent 26%),linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.38));z-index:-3;pointer-events:none}.fanlink-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 16px}.fanlink-card{width:min(100%,350px);text-align:center;color:#121216}.fanlink-cover-frame{width:190px;margin:0 auto -1px;position:relative;z-index:2}.fanlink-cover-frame:before{content:"";position:absolute;left:10px;right:10px;bottom:-10px;height:38px;background:rgba(0,0,0,.38);filter:blur(18px);border-radius:50%;z-index:-1}.fanlink-cover{width:190px;height:190px;display:flex;align-items:center;justify-content:center;object-fit:cover;background:#111;border-radius:2px;box-shadow:0 18px 55px rgba(0,0,0,.42)}.fanlink-cover-placeholder{color:#fff;font-size:42px;font-weight:900;letter-spacing:-.07em;background:linear-gradient(135deg,#111,#34344a)}.fanlink-panel{background:rgba(255,255,255,.94);padding:24px 0 16px;box-shadow:0 24px 80px rgba(0,0,0,.22);backdrop-filter:blur(14px)}.fanlink-header{padding:0 28px 12px}.fanlink-header h1{margin:0 0 3px;color:#16161b;font-size:22px;font-weight:800;letter-spacing:-.035em;line-height:1.08}.fanlink-header p{margin:0;color:#5f6068;font-size:13px;font-weight:700}.fanlink-description{margin:10px auto 0;color:#62636a;font-size:12px;line-height:1.3;max-width:260px}.fanlink-list{border-top:1px solid rgba(0,0,0,.18);margin:0 20px;padding-top:7px}.fanlink-row{height:43px;display:flex;align-items:center;justify-content:space-between;gap:14px;text-decoration:none;color:#15151a;border-radius:0;padding:0 0;border-bottom:0;background:transparent;transition:transform .16s ease,opacity .16s ease}.fanlink-row:hover{transform:translateX(2px);opacity:.86}.fanlink-brand{display:flex;align-items:center;gap:10px;min-width:0}.fanlink-logo{width:24px;height:24px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 24px;color:#fff;background:#15151a;font-size:13px;font-weight:900;line-height:1}.fanlink-name{font-size:15px;font-weight:800;letter-spacing:-.018em;color:#17171c;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.fanlink-action{display:inline-flex;align-items:center;justify-content:center;min-width:58px;height:23px;padding:0 11px;border-radius:999px;background:#050507;color:#fff;font-size:10px;font-weight:900;letter-spacing:-.01em;line-height:1;box-shadow:0 5px 12px rgba(0,0,0,.18)}.fanlink-row.platform-spotify .fanlink-logo{background:#1DB954}.fanlink-row.platform-apple .fanlink-logo{background:#050507}.fanlink-row.platform-youtube .fanlink-logo{background:#ff0033}.fanlink-row.platform-amazon .fanlink-logo{background:#ff9900;color:#111}.fanlink-row.platform-deezer .fanlink-logo{background:linear-gradient(135deg,#ff2d55,#a238ff,#00c7ff)}.fanlink-row.platform-tidal .fanlink-logo{background:#050507}.fanlink-row.platform-soundcloud .fanlink-logo{background:#ff6a00}.fanlink-row.platform-bandcamp .fanlink-logo{background:#629aa9}.fanlink-empty{margin:0 20px;padding:16px;border-top:1px solid rgba(0,0,0,.16);color:#666;font-size:13px}.fanlink-footer{margin-top:12px;color:rgba(255,255,255,.68);font-size:11px;letter-spacing:.01em;text-shadow:0 2px 15px rgba(0,0,0,.42)}.fanlink-footer strong{color:#fff;font-weight:800}.fanlink-footer span{text-transform:uppercase;font-size:9px;letter-spacing:.08em}@media(max-width:480px){.fanlink-shell{align-items:flex-start;padding-top:34px}.fanlink-card{width:min(100%,330px)}.fanlink-cover-frame,.fanlink-cover{width:178px;height:178px}.fanlink-panel{padding-top:22px}.fanlink-header{padding-left:22px;padding-right:22px}.fanlink-list{margin-left:18px;margin-right:18px}.fanlink-name{max-width:160px}.fanlink-bg{filter:blur(34px) saturate(1.18);opacity:.85}}


/* Phase 1.8 - cover width aligned to fanlink panel */
.fanlink-cover-frame{width:100%;margin:0 auto 0;}
.fanlink-cover{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;border-radius:2px;}
.fanlink-cover-frame:before{left:18px;right:18px;bottom:-10px;}
@media(max-width:480px){.fanlink-cover-frame,.fanlink-cover{width:100%;height:auto;aspect-ratio:1/1;}}

/* Phase 1.8 - upload progress modal */
.upload-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(5,5,8,.78);backdrop-filter:blur(14px);z-index:9999;padding:18px;}
.upload-modal.is-visible{display:flex;}
.upload-modal-card{width:min(100%,420px);border:1px solid var(--line);border-radius:26px;background:linear-gradient(180deg,rgba(255,255,255,.11),rgba(255,255,255,.045));box-shadow:0 30px 90px rgba(0,0,0,.55);padding:24px;text-align:center;}
.upload-modal-card h3{font-size:28px;margin-bottom:8px;}
.upload-progress-track{height:12px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden;margin:18px 0 10px;}
.upload-progress-bar{height:100%;width:0%;border-radius:999px;background:linear-gradient(135deg,var(--red),var(--red2));transition:width .15s ease;}
.upload-percent{font-size:34px;font-weight:900;letter-spacing:-.04em;}
.upload-modal-note{color:var(--muted);font-size:14px;margin-top:8px;}
.upload-error{display:none;margin-top:12px;color:#ff8c99;font-weight:800;}

/* Phase 1.10 - White premium admin redesign */
:root{--admin-bg:#f7f8fb;--admin-panel:#ffffff;--admin-text:#13131a;--admin-muted:#6d7280;--admin-line:rgba(18,18,28,.10);--admin-soft:#f1f3f7;}
body:not(.fanlink-body):not(.smart-premium-body){background:radial-gradient(circle at 8% -8%,rgba(239,35,60,.15),transparent 32%),radial-gradient(circle at 98% 0%,rgba(20,20,25,.08),transparent 28%),linear-gradient(180deg,#fff,#f7f8fb 58%,#eef1f6);color:var(--admin-text)}
body:not(.fanlink-body) .wrap{max-width:1220px;padding:30px 22px 96px}.topbar{position:sticky;top:14px;z-index:20;padding:14px 16px;border:1px solid var(--admin-line);border-radius:26px;background:rgba(255,255,255,.82);box-shadow:0 18px 55px rgba(30,35,55,.10);backdrop-filter:blur(18px);margin-bottom:28px}.brand{color:#121219;display:flex;align-items:center;gap:8px}.brand:before{content:"";width:34px;height:34px;flex:0 0 34px;border-radius:0;background:url('logos/oum-admin-logo.jpg') center/contain no-repeat;box-shadow:none}.brand span{color:#ef233c}.nav{align-items:center}.btn,.button,button,input[type=submit]{border-radius:999px;background:linear-gradient(135deg,#ef233c,#bd1028);color:#fff;padding:12px 18px;box-shadow:0 15px 34px rgba(239,35,60,.22);white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:8px;line-height:1}.btn.secondary{background:#121219;color:#fff;box-shadow:0 14px 34px rgba(18,18,25,.15)}.btn.ghost{background:#fff;color:#16161d;border:1px solid var(--admin-line);box-shadow:0 10px 26px rgba(26,26,36,.07)}.btn.danger{background:linear-gradient(135deg,#ef4444,#991b1b)}.card{background:rgba(255,255,255,.94);border:1px solid var(--admin-line);box-shadow:0 22px 60px rgba(32,38,54,.09);color:var(--admin-text)}.form-card{padding:26px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin:6px 0 22px}.page-head h1{font-size:clamp(38px,5vw,66px);color:#121219}.eyebrow{display:inline-flex;margin-bottom:10px;border-radius:999px;padding:7px 12px;background:#111;color:#fff;font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.head-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content: flex-end}.muted{color:var(--admin-muted)}.small{font-size:13px;line-height:1.35}h1,h2,h3{color:#121219}h2{font-size:30px}.grid{gap:20px}.table{background:#fff;border-radius:22px;overflow:hidden}.table th{color:#6d7280;text-transform:uppercase;font-size:12px;letter-spacing:.08em;background:#f5f6f9}.table th,.table td{border-color:var(--admin-line);vertical-align:middle}.pill{border-color:var(--admin-line);background:#f5f6f9;color:#3f4350}.metric{color:#121219}.copybox{background:#f6f7fa;border-color:var(--admin-line);color:#252733}.notice{background:#fff;border-color:var(--admin-line);color:#121219;box-shadow:0 16px 44px rgba(24,28,42,.08)}.notice.success{background:#ecfdf5;border-color:rgba(16,185,129,.24);color:#065f46}label{color:#262936}input,select,textarea{background:#fff;color:#14141b;border:1px solid var(--admin-line);outline:none}input:focus,select:focus,textarea:focus{border-color:rgba(239,35,60,.45);box-shadow:0 0 0 4px rgba(239,35,60,.09)}.links-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.platform-field{padding:14px;border:1px solid var(--admin-line);border-radius:20px;background:#fafbfc}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.cover-preview img{max-width:160px;border-radius:20px;box-shadow:0 18px 44px rgba(20,20,28,.18);margin-top:10px}.sticky-save{position:sticky;bottom:18px;z-index:25;margin-top:18px;padding:13px;border:1px solid var(--admin-line);border-radius:24px;background:rgba(255,255,255,.86);box-shadow:0 20px 58px rgba(20,26,40,.13);backdrop-filter:blur(18px);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.url-builder{display:flex;align-items:center;border:1px solid var(--admin-line);border-radius:16px;background:#fff;overflow:hidden}.url-builder span{flex:0 0 auto;padding:0 0 0 13px;color:#7b8090;font-weight:800;font-size:14px;white-space:nowrap}.url-builder input{border:0;border-radius:0;box-shadow:none;padding-left:4px}.upload-modal-card{background:#fff;color:#15151c;border:1px solid var(--admin-line)}.upload-progress-track{background:#eceff4}.upload-modal-note{color:#6d7280}.login .card{box-shadow:0 30px 80px rgba(28,34,50,.12)}
@media(max-width:820px){.page-head{align-items:flex-start;flex-direction:column}.links-grid,.form-row{grid-template-columns:1fr}.sticky-save{justify-content:stretch}.sticky-save .btn,.sticky-save button{width:100%}.topbar{position:static}.nav a{flex:1}.url-builder{display:block}.url-builder span{display:block;padding:10px 13px 0;white-space:normal}.url-builder input{padding-left:13px}.table{display:block;overflow-x:auto}}

/* Phase 1.10 - Fanlink preview player + platform logo rows */
.fanlink-card{width:min(100%,370px)}.fanlink-panel{background:rgba(255,255,255,.965);border-radius:0 0 4px 4px}.fanlink-header{padding:6px 30px 20px}.fanlink-header h1{font-size:24px}.fanlink-description{margin-top:12px;color:#6b6d76;font-size:13px;font-weight:700}.fanlink-play{margin:13px auto 0;height:36px;padding:0 16px;border-radius:999px;background:#111;color:#fff;box-shadow:0 12px 28px rgba(0,0,0,.18);font-size:12px;letter-spacing:.12em;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px}.play-dot{font-size:10px;line-height:1}.fanlink-preview-wrap{margin:12px 0 0}.fanlink-preview-wrap[hidden]{display:none}.fanlink-spotify-embed{border-radius:14px;display:block;background:#111}#fanlink-audio{width:100%;height:42px}.fanlink-list{margin:0 22px;padding-top:9px}.fanlink-row{height:48px}.fanlink-brand{gap:12px;flex:1}.fanlink-logo{width:116px;height:28px;border-radius:0;background:transparent!important;color:#111;justify-content:flex-start;flex:0 0 116px}.fanlink-logo-svg{width:116px;height:28px;display:block}.fanlink-name{display:none}.fanlink-action{min-width:64px;height:25px;background:#111;color:#fff;font-size:12px}.fanlink-row.platform-amazon .fanlink-action{background:#111;color:#fff}.fanlink-row.platform-youtube .fanlink-action{background:#111;color:#fff}.fanlink-row.platform-custom .fanlink-name{display:block;max-width:150px}.fanlink-row.platform-custom .fanlink-logo{width:24px;flex-basis:24px;border-radius:999px;background:#111!important;color:#fff}.fanlink-row.platform-custom .fanlink-logo svg{display:none}.fanlink-row.platform-custom .fanlink-logo:before{content:"↗";font-size:13px;font-weight:900}.fanlink-footer{margin-top:14px}.fanlink-cover-frame,.fanlink-cover{border-radius:2px 2px 0 0}.fanlink-bg{filter:blur(42px) saturate(1.22);opacity:.88}.fanlink-vignette{background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.08),transparent 25%),linear-gradient(180deg,rgba(255,255,255,.08),rgba(0,0,0,.44))}
@media(max-width:480px){.fanlink-card{width:min(100%,340px)}.fanlink-header{padding-left:24px;padding-right:24px}.fanlink-logo{width:108px;flex-basis:108px}.fanlink-logo-svg{width:108px}.fanlink-action{min-width:58px}.fanlink-row{height:47px}}

/* Phase 1.12 - dashboard delete button and vinyl custom icon */
.table-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.inline-delete-form{display:inline-flex;margin:0}.inline-delete-form button{font-size:14px}.btn.danger,.inline-delete-form .btn.danger{background:linear-gradient(135deg,#f97316,#dc2626)!important;color:#fff!important;border:0!important;box-shadow:0 14px 30px rgba(220,38,38,.20)!important}.btn.danger:hover{transform:translateY(-1px);filter:saturate(1.05)}
.fanlink-row.platform-custom .fanlink-logo{width:116px!important;height:28px!important;flex:0 0 116px!important;border-radius:0!important;background:transparent!important;color:#111!important;justify-content:flex-start!important}.fanlink-row.platform-custom .fanlink-logo svg{display:block!important}.fanlink-row.platform-custom .fanlink-logo:before{content:none!important}.fanlink-row.platform-custom .fanlink-name{display:none!important}.fanlink-row.platform-custom .fanlink-action{background:#111;color:#fff}
@media(max-width:480px){.table-actions{justify-content:flex-start}.table-actions .btn,.inline-delete-form button{padding:10px 13px}.fanlink-row.platform-custom .fanlink-logo{width:108px!important;flex-basis:108px!important}}

/* Phase 1.13 - Original-style platform marks + Titillium Web everywhere */
*,*::before,*::after{font-family:'Titillium Web',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important;}
.copybox{font-family:'Titillium Web',system-ui,sans-serif!important;font-weight:700;letter-spacing:.01em;}
.fanlink-body,.fanlink-body *{font-family:'Titillium Web',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important;}
.fanlink-list{display:grid;gap:7px;border-top:1px solid rgba(0,0,0,.13);padding-top:11px;}
.fanlink-row{height:52px;padding:0 2px;border-radius:14px;}
.fanlink-row:hover{background:rgba(0,0,0,.035);transform:translateX(2px);opacity:1;}
.fanlink-brand{gap:11px;min-width:0;}
.fanlink-logo,.fanlink-row.platform-custom .fanlink-logo{width:32px!important;height:32px!important;flex:0 0 32px!important;border-radius:999px!important;background:transparent!important;color:#111!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;}
.fanlink-logo-svg{width:32px!important;height:32px!important;display:block!important;}
.fanlink-name,.fanlink-row.platform-custom .fanlink-name{display:block!important;max-width:175px!important;font-family:'Titillium Web',system-ui,sans-serif!important;font-size:15.5px;font-weight:800;letter-spacing:-.015em;color:#17171c;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.fanlink-action{min-width:62px;height:26px;border-radius:999px;font-family:'Titillium Web',system-ui,sans-serif!important;font-size:11px;font-weight:900;text-transform:none;letter-spacing:.01em;background:#111;color:#fff;}
.fanlink-row.platform-custom .fanlink-logo:before{content:none!important;}
.fanlink-row.platform-custom .fanlink-logo svg{display:block!important;}
.fanlink-header h1,.fanlink-header p,.fanlink-description,.fanlink-play,.fanlink-footer,.fanlink-action,.fanlink-name{font-family:'Titillium Web',system-ui,sans-serif!important;}
@media(max-width:480px){.fanlink-row{height:50px}.fanlink-logo,.fanlink-row.platform-custom .fanlink-logo{width:30px!important;height:30px!important;flex-basis:30px!important}.fanlink-logo-svg{width:30px!important;height:30px!important}.fanlink-name,.fanlink-row.platform-custom .fanlink-name{max-width:145px!important;font-size:14.5px}.fanlink-action{min-width:58px;height:25px;font-size:10.5px}}

/* Phase 1.14 - Icons8 CDN platform icons + fanlink microfixes */
.fanlink-header{padding:6px 30px 24px!important;}
.fanlink-action{font-size:12px!important;}
.fanlink-logo-img{width:32px!important;height:32px!important;display:block!important;object-fit:contain!important;border-radius:8px;}
.fanlink-row.platform-custom .fanlink-logo-img{display:none!important;}
.fanlink-preview-wrap{position:relative;min-height:80px;}
.fanlink-spotify-embed{opacity:0;transform:translateY(4px);transition:opacity .22s ease,transform .22s ease;}
.fanlink-spotify-embed.is-loaded{opacity:1;transform:translateY(0);}
.fanlink-player-loader{height:80px;border-radius:14px;background:linear-gradient(135deg,#111,#23232b);color:#fff;display:flex;align-items:center;justify-content:center;gap:9px;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;position:absolute;inset:0;z-index:2;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);}
.fanlink-player-loader.is-hidden{opacity:0;visibility:hidden;transition:opacity .18s ease,visibility .18s ease;}
.fanlink-loader-dot{width:9px;height:9px;border-radius:999px;background:#fff;animation:fanlinkPulse .8s ease-in-out infinite alternate;}
@keyframes fanlinkPulse{from{opacity:.35;transform:scale(.82)}to{opacity:1;transform:scale(1.12)}}
@media(max-width:480px){.fanlink-action{font-size:12px!important}.fanlink-header{padding:6px 24px 24px!important;}}

/* Phase 1.15 microfixes */
.cover-upload-control{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:6px;}
.cover-file-input{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important;}
.cover-file-button{margin:0!important;display:inline-flex!important;align-items:center;justify-content:center;gap:9px;border-radius:999px;background:linear-gradient(135deg,#111118,#ef233c);color:#fff!important;padding:12px 18px;font-weight:900;letter-spacing:-.01em;box-shadow:0 16px 34px rgba(239,35,60,.22);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease;}
.cover-file-button:hover{transform:translateY(-1px);box-shadow:0 20px 42px rgba(239,35,60,.28);}
.cover-file-icon{width:22px;height:22px;border-radius:999px;background:rgba(255,255,255,.16);display:inline-flex;align-items:center;justify-content:center;font-size:15px;line-height:1;}
.cover-file-name{font-size:13px;font-weight:800;color:#747987;max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.brand{font-size:23px;line-height:1;gap:10px;}
.brand:before{content:"";width:34px;height:34px;flex:0 0 34px;border-radius:0;background:url('logos/oum-admin-logo.jpg') center/contain no-repeat!important;box-shadow:none!important;}
.fanlink-row.platform-bandcamp .fanlink-logo-img{content:url('logos/bandcamp.svg');}
.fanlink-row.platform-youtube .fanlink-action,.fanlink-row.platform-bandcamp .fanlink-action{background:#111;color:#fff;}


/* Phase 1.17 - Genre label in fanlink */
.fanlink-genre{display:inline-flex;align-items:center;justify-content:center;margin:9px auto 0;padding:4px 11px;border-radius:999px;background:rgba(0,0,0,.065);color:#3f414a;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;line-height:1.2;}
.fanlink-header p + .fanlink-genre + .fanlink-play{margin-top:12px;}
@media(max-width:480px){.fanlink-genre{font-size:10.5px;padding:4px 10px;}}


/* Phase 1.18 - center create release card button */
.create-release-card{display:flex!important;align-items:center!important;justify-content:center!important;min-height:150px;text-align:center;}
.create-release-card .btn{margin:auto;}
@media(max-width:780px){.create-release-card{min-height:120px;}}

/* Phase 1.20 - mobile fanlink background, admin responsive tables, social links */
.smart-url-help{overflow-wrap:anywhere;word-break:break-word;max-width:100%;line-height:1.35;}
.smart-url-help strong{overflow-wrap:anywhere;word-break:break-word;}
.fanlink-body{background-attachment:fixed;}
.fanlink-bg,.fanlink-vignette{position:fixed!important;pointer-events:none!important;backface-visibility:hidden;transform:translate3d(0,0,0) scale(1.12);will-change:transform;contain:paint;}
.fanlink-vignette{transform:translate3d(0,0,0);}
.fanlink-socials{display:flex;align-items:center;justify-content:center;gap:12px;margin:14px auto 0;padding:0 18px;}
.fanlink-social{width:34px;height:34px;border-radius:999px;background:rgba(255,255,255,.94);display:inline-flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 10px 26px rgba(0,0,0,.18);transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease;}
.fanlink-social:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.24);opacity:.96;}
.fanlink-social .fanlink-logo-img{width:25px!important;height:25px!important;border-radius:7px!important;}
.fanlink-social .fanlink-logo-svg{width:25px!important;height:25px!important;}
@media(max-width:640px){
  body:not(.fanlink-body) .wrap{padding:14px 12px 84px;max-width:100%;overflow-x:hidden;}
  .topbar{border-radius:20px;padding:13px;margin-bottom:18px;}
  .brand{font-size:18px;line-height:1.05;}
  .brand:before{width:28px!important;height:28px!important;flex-basis:28px!important;}
  .nav{width:100%;display:grid;grid-template-columns:1fr;gap:8px;}
  .nav .btn{width:100%;text-align:center;padding:11px 13px;}
  .card{border-radius:22px;padding:17px;overflow:hidden;}
  h1{font-size:34px;line-height:1;}
  h2{font-size:25px;}
  .metric{font-size:32px;}
  .copybox{font-size:12px;line-height:1.32;white-space:normal;overflow-wrap:anywhere;word-break:break-word;}
  .dashboard-release-table{display:block;width:100%;border-collapse:separate;overflow:visible;}
  .dashboard-release-table thead{display:none;}
  .dashboard-release-table tbody{display:grid;gap:13px;width:100%;}
  .dashboard-release-table tr{display:block;background:#fff;border:1px solid var(--admin-line);border-radius:18px;padding:13px;box-shadow:0 12px 30px rgba(30,35,55,.07);}
  .dashboard-release-table td{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-bottom:1px solid rgba(30,35,55,.08);padding:9px 0;text-align:right;}
  .dashboard-release-table td:last-child{border-bottom:0;display:block;text-align:left;padding-bottom:0;}
  .dashboard-release-table td:nth-child(1)::before{content:'Release';}
  .dashboard-release-table td:nth-child(2)::before{content:'Smart link';}
  .dashboard-release-table td:nth-child(3)::before{content:'Visite';}
  .dashboard-release-table td:nth-child(4)::before{content:'Click';}
  .dashboard-release-table td:nth-child(5)::before{content:'Spotify';}
  .dashboard-release-table td::before{flex:0 0 auto;color:#737887;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;text-align:left;}
  .dashboard-release-table td > *:not(.table-actions){min-width:0;}
  .dashboard-release-table .table-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px;}
  .dashboard-release-table .table-actions .btn,.dashboard-release-table .inline-delete-form,.dashboard-release-table .inline-delete-form button{width:100%;text-align:center;justify-content:center;}
  .dashboard-release-table .inline-delete-form{display:block;}
  .url-builder{max-width:100%;}
  .url-builder span,.url-builder input{font-size:13px;overflow-wrap:anywhere;word-break:break-word;}
  .smart-url-help{font-size:12px;}
}
@media(max-width:480px){
  .fanlink-body{overflow-x:hidden;}
  .fanlink-bg{inset:-45px;filter:blur(26px) saturate(1.14)!important;opacity:.86;transform:translate3d(0,0,0) scale(1.08)!important;}
  .fanlink-vignette{transform:translate3d(0,0,0)!important;}
  .fanlink-shell{min-height:100svh;align-items:flex-start;padding-top:28px;padding-bottom:34px;}
  .fanlink-card{width:min(100%,338px);}
  .fanlink-socials{margin-top:12px;gap:10px;}
  .fanlink-social{width:32px;height:32px;}
}

/* Phase 1.21 - Smartlink accordion menu + login centering */
.smartlinks-card{scroll-margin-top:118px;}
.smartlinks-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px;}
.release-accordion{display:grid;gap:12px;}
.release-item{border:1px solid var(--admin-line);border-radius:22px;background:#fff;box-shadow:0 14px 36px rgba(25,30,44,.06);overflow:hidden;}
.release-item[open]{box-shadow:0 20px 48px rgba(25,30,44,.10);}
.release-summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 18px 17px;cursor:pointer;user-select:none;}
.release-summary::-webkit-details-marker{display:none;}
.release-main{display:block;min-width:0;}
.release-title{display:block;color:#121219;font-size:19px;font-weight:900;letter-spacing:-.025em;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.release-artist{display:block;margin-top:4px;color:#737887;font-size:13px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.release-chevron{width:34px;height:34px;flex:0 0 34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#f3f4f7;color:#121219;font-size:22px;font-weight:900;line-height:1;transition:transform .18s ease,background .18s ease;}
.release-item[open] .release-chevron{transform:rotate(180deg);background:#121219;color:#fff;}
.release-details{border-top:1px solid var(--admin-line);padding:16px 18px 18px;background:linear-gradient(180deg,#fff,#fafbfc);}
.release-url-block{display:grid;gap:8px;margin-bottom:14px;}
.detail-label{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.09em;color:#7b8090;}
.release-metrics-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:14px;}
.mini-metric{border:1px solid var(--admin-line);border-radius:18px;background:#fff;padding:12px;text-align:center;}
.mini-metric span{display:block;color:#7b8090;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.07em;}
.mini-metric strong{display:block;margin-top:3px;color:#121219;font-size:25px;line-height:1;font-weight:900;}
.release-actions{justify-content:flex-start;}
.login-body{min-height:100vh;background:radial-gradient(circle at 20% 0%,rgba(239,35,60,.12),transparent 34%),linear-gradient(135deg,#f7f8fb,#fff 48%,#f3f5f9);}
.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;}
.login-shell .login{width:min(100%,440px);margin:0;}
.login-brand{justify-content:flex-start;margin-bottom:10px;font-size:24px!important;}
.login form button{width:100%;margin-top:6px;}
@media(max-width:820px){
  .smartlinks-card{scroll-margin-top:20px;}
  .smartlinks-head{align-items:stretch;flex-direction:column;}
  .smartlinks-head .btn{width:100%;}
  .release-summary{padding:16px 14px;}
  .release-title{font-size:17px;}
  .release-details{padding:14px;}
  .release-metrics-row{grid-template-columns:1fr 1fr 1fr;gap:8px;}
  .mini-metric{padding:10px 7px;border-radius:15px;}
  .mini-metric strong{font-size:22px;}
  .release-actions{display:grid!important;grid-template-columns:1fr 1fr;gap:8px;width:100%;}
  .release-actions .btn,.release-actions .inline-delete-form,.release-actions .inline-delete-form button{width:100%;justify-content:center;text-align:center;}
  .release-actions .inline-delete-form{display:block;}
  .login-shell{align-items:center;padding:18px;}
  .login-brand{font-size:21px!important;}
}
@media(max-width:420px){
  .release-metrics-row{grid-template-columns:1fr;}
  .release-actions{grid-template-columns:1fr!important;}
  .release-title,.release-artist{white-space:normal;}
}

/* Phase 1.22 - fanlink header padding microfix */
.fanlink-header{padding:8px 30px 35px!important;}
@media(max-width:480px){.fanlink-header{padding:8px 24px 35px!important;}}


/* Phase 1.23 - dashboard home cards, smartlink release section, fanlink mobile background fix */
.dashboard-feature-grid{grid-column:span 12;display:grid!important;grid-template-columns:1fr 1fr;gap:18px;background:transparent!important;border:0!important;box-shadow:none!important;padding:0!important;backdrop-filter:none!important;}
.dashboard-feature-card{position:relative;min-height:260px;border-radius:30px;overflow:hidden;text-decoration:none;color:#fff;display:flex;align-items:flex-end;padding:26px;box-shadow:0 26px 74px rgba(20,26,40,.16);isolation:isolate;background:#14141b;}
.dashboard-feature-card .feature-bg{position:absolute;inset:-22px;background-image:var(--feature-bg,linear-gradient(135deg,#14141b,#ef233c));background-size:cover;background-position:center;filter:blur(18px) saturate(1.18);transform:scale(1.08);z-index:-2;opacity:.78;}
.dashboard-feature-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.68));z-index:-1;}
.dashboard-feature-ads .feature-bg{background-image:radial-gradient(circle at 20% 20%,rgba(239,35,60,.9),transparent 35%),radial-gradient(circle at 78% 30%,rgba(17,24,39,.9),transparent 42%),linear-gradient(135deg,#111827,#ef233c);}
.feature-content{display:grid;gap:8px;max-width:360px;position:relative;z-index:2;}
.feature-content strong{font-size:44px;line-height:.92;font-weight:900;letter-spacing:-.055em;color:#fff;}
.feature-content small{font-size:14px;line-height:1.3;color:rgba(255,255,255,.82);font-weight:700;}
.feature-arrow,.feature-badge{position:absolute;right:22px;top:22px;width:42px;height:42px;border-radius:999px;background:#fff;color:#111;display:inline-flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 14px 36px rgba(0,0,0,.18);}
.feature-badge{width:auto;padding:0 14px;text-transform:uppercase;font-size:12px;letter-spacing:.08em;}
.dashboard-feature-card.is-disabled{cursor:default;}
.release-summary{display:grid!important;grid-template-columns:auto minmax(0,1fr) auto;}
.release-cover-thumb{width:58px;height:58px;flex:0 0 58px;border-radius:14px;overflow:hidden;background:linear-gradient(135deg,#111,#ef233c);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(20,26,40,.14);}
.release-cover-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.release-cover-thumb span{color:#fff;font-size:13px;font-weight:900;letter-spacing:-.04em;}
.release-title{padding-top:4px;}
.fanlink-body{background:#07070a!important;min-height:100dvh;overscroll-behavior-y:none;}
.fanlink-bg{position:fixed!important;top:-8vh!important;left:-8vw!important;right:auto!important;bottom:auto!important;width:116vw!important;height:116dvh!important;min-height:116vh!important;inset:auto!important;background-size:cover!important;background-position:center center!important;transform:none!important;will-change:auto!important;contain:strict!important;backface-visibility:hidden!important;}
@supports (height:100lvh){.fanlink-bg{height:116lvh!important;}}
.fanlink-vignette{position:fixed!important;inset:0!important;transform:none!important;will-change:auto!important;contain:strict!important;}
.fanlink-name,.fanlink-row.platform-custom .fanlink-name{font-size:16.5px!important;line-height:1.05!important;}
.fanlink-action{min-width:72px!important;height:30px!important;font-size:13px!important;padding:0 14px!important;}
.fanlink-row{height:56px!important;}
@media(max-width:820px){
  .dashboard-feature-grid{grid-template-columns:1fr;gap:14px;}
  .dashboard-feature-card{min-height:210px;padding:22px;border-radius:26px;}
  .feature-content strong{font-size:38px;}
  .release-summary{gap:12px;padding:14px!important;}
  .release-cover-thumb{width:54px;height:54px;flex-basis:54px;border-radius:13px;}
}
@media(max-width:480px){
  .fanlink-bg{top:-10vh!important;left:-12vw!important;width:124vw!important;height:124dvh!important;min-height:124vh!important;filter:blur(24px) saturate(1.12)!important;opacity:.9!important;}
  @supports (height:100lvh){.fanlink-bg{height:124lvh!important;}}
  .fanlink-name,.fanlink-row.platform-custom .fanlink-name{font-size:15.8px!important;max-width:158px!important;}
  .fanlink-action{min-width:70px!important;height:30px!important;font-size:13px!important;}
  .fanlink-row{height:55px!important;}
}


/* Phase 1.24 - upload validation + dashboard white feature cards */
.cover-file-name.is-error{color:#dc2626!important;}
.dashboard-feature-card{background:#ffffff!important;}


/* Phase 1.25 - separated social links fields + website icon */
.social-link-card{position:relative;overflow:hidden;}
.social-link-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,#ef233c,#111118,#3b82f6);}
.social-links-grid .platform-field{background:linear-gradient(180deg,#ffffff,#f7f8fb);border:1px solid var(--admin-line);border-radius:18px;padding:14px;box-shadow:0 12px 28px rgba(25,30,45,.06);}
.social-links-grid .platform-field label{display:flex;align-items:center;gap:8px;margin-top:0;}
.fanlink-social.platform-website .fanlink-logo-img{border-radius:8px!important;}
@media(max-width:820px){.social-links-grid .platform-field{padding:12px;}}


/* Phase 1.32 - Mobile fanlink fixed stable blur layer
   Desktop untouched. Mobile only: keeps the cover visible, fixed and blurred,
   but removes the blur from the fixed scrolling layer to avoid iOS/Android
   repaint lag after repeated down/up scrolling. */
@media (max-width: 820px) {
  body.fanlink-body {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    min-height: 100vh !important;
    background: #07070a !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-x: none !important;
  }

  body.fanlink-body .fanlink-bg {
    display: block !important;
    position: fixed !important;
    top: -70px !important;
    left: -70px !important;
    right: auto !important;
    bottom: auto !important;
    inset: auto !important;
    width: calc(100vw + 140px) !important;
    height: calc(100svh + 140px) !important;
    min-height: calc(100vh + 140px) !important;
    z-index: 0 !important;
    overflow: hidden !important;
    opacity: 1 !important;
    filter: none !important;
    transform: none !important;
    contain: layout paint style !important;
    will-change: auto !important;
    backface-visibility: hidden !important;
    pointer-events: none !important;
    background-size: 0 0 !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-color: #07070a !important;
  }

  body.fanlink-body .fanlink-bg::before {
    content: "" !important;
    position: absolute !important;
    inset: -44px !important;
    background-image: inherit !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    filter: blur(26px) saturate(1.16) !important;
    opacity: .94 !important;
    transform: translate3d(0,0,0) !important;
    backface-visibility: hidden !important;
    pointer-events: none !important;
  }

  body.fanlink-body .fanlink-bg::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.40)) !important;
    pointer-events: none !important;
  }

  body.fanlink-body .fanlink-vignette {
    position: fixed !important;
    inset: 0 !important;
    z-index: 1 !important;
    background: radial-gradient(circle at 50% 36%, rgba(255,255,255,.08), transparent 33%), linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.24)) !important;
    transform: none !important;
    contain: paint !important;
    will-change: auto !important;
    pointer-events: none !important;
  }

  body.fanlink-body .fanlink-shell {
    position: relative !important;
    z-index: 2 !important;
    min-height: 100vh !important;
    height: auto !important;
    overflow: visible !important;
  }

  body.fanlink-body .fanlink-card {
    position: relative !important;
    z-index: 3 !important;
  }
}

/* Phase 1.33 - Recent events internal scroll + clear-only-recent action */
.recent-events-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;}
.recent-events-head h2{margin-bottom:6px;}
.clear-recent-form{margin:0;display:flex;align-items:center;justify-content:flex-end;}
.btn.danger-outline{background:#fff!important;color:#b42318!important;border:1px solid rgba(180,35,24,.26)!important;box-shadow:0 10px 26px rgba(180,35,24,.08)!important;}
.btn.danger-outline:hover{background:#fff5f5!important;transform:translateY(-1px);}
.recent-events-scroll{max-height:560px;overflow:auto;border:1px solid var(--admin-line);border-radius:22px;background:#fff;-webkit-overflow-scrolling:touch;}
.recent-events-scroll .table{border-radius:0;box-shadow:none;}
.recent-events-scroll .table th{position:sticky;top:0;z-index:2;}
.recent-events-table td{vertical-align:top;}
@media(max-width:820px){.recent-events-head{flex-direction:column}.clear-recent-form,.clear-recent-form .btn{width:100%}.recent-events-scroll{max-height:520px}.recent-events-table{min-width:720px}}


/* Phase 2.0 - Campagne Ads Facebook / Instagram */
.dashboard-feature-ads{cursor:pointer!important;}
.ads-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
.ads-intro-card{grid-column:auto!important;}
.campaign-type-badge{width:78px;height:34px;border-radius:999px;background:linear-gradient(135deg,#111118,#ef233c);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.05em;}
.campaign-summary{grid-template-columns:auto minmax(0,1fr) auto!important;}
.campaign-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.campaign-placement-row{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 14px;}
.empty-campaign-state{text-align:center;padding:36px 18px;}
.campaign-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:22px;align-items:start;}
.campaign-main-form{display:grid;gap:16px;min-width:0;}
.ad-step-card{background:#fff;border:1px solid var(--admin-line);border-radius:26px;padding:20px;box-shadow:0 18px 42px rgba(25,30,44,.08);}
.ad-step-head{display:flex;align-items:center;gap:13px;margin-bottom:16px;}
.ad-step-head>span{width:38px;height:38px;border-radius:999px;background:linear-gradient(135deg,#ef233c,#111118);color:#fff;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 28px rgba(239,35,60,.18);}
.ad-step-head h2{margin:0;font-size:27px;color:#111118;}
.ad-step-head p{margin:2px 0 0;color:#727787;font-weight:700;}
.promo-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;}
.promo-type-option{margin:0!important;border:1px solid var(--admin-line);border-radius:20px;padding:14px;cursor:pointer;background:linear-gradient(180deg,#fff,#f8f9fc);transition:.16s ease;}
.promo-type-option:hover{transform:translateY(-1px);box-shadow:0 16px 32px rgba(25,30,44,.08);}
.promo-type-option input{width:auto;margin-right:6px;}
.promo-type-option strong{display:inline-block;color:#111118;font-size:16px;}
.promo-type-option small{display:block;margin-top:6px;color:#777d8c;font-weight:700;line-height:1.25;}
.placement-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px;}
.placement-grid label{display:flex;align-items:center;gap:7px;margin:0!important;background:#f8f9fc;border:1px solid var(--admin-line);border-radius:16px;padding:11px;color:#111118;}
.placement-grid input{width:auto;}
.form-row.three-cols{grid-template-columns:repeat(3,1fr);}
.campaign-preview-panel{position:sticky;top:112px;display:grid;gap:14px;}
.preview-tabs{display:flex;gap:8px;background:#fff;border:1px solid var(--admin-line);border-radius:999px;padding:6px;box-shadow:0 12px 30px rgba(25,30,44,.07);}
.preview-tabs button{flex:1;box-shadow:none;background:transparent;color:#111118;border-radius:999px;padding:10px 12px;}
.preview-tabs button.active{background:#111118;color:#fff;}
.ad-phone-preview{height:640px;border-radius:34px;background:#050507;color:#fff;position:relative;overflow:hidden;box-shadow:0 28px 80px rgba(0,0,0,.28);border:8px solid #111118;}
.ig-top{position:absolute;top:18px;left:18px;font-size:18px;font-weight:900;z-index:2;}
.ad-artwork{position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(239,35,60,.9),transparent 30%),radial-gradient(circle at 70% 30%,rgba(255,255,255,.26),transparent 24%),linear-gradient(160deg,#111118,#ef233c 55%,#050507);display:flex;align-items:center;justify-content:center;font-size:94px;font-weight:900;}
.ad-preview-bottom{position:absolute;left:18px;right:18px;bottom:22px;display:grid;gap:8px;text-shadow:0 2px 18px rgba(0,0,0,.45);}
.ad-preview-bottom strong{font-size:17px;}
.ad-preview-bottom button{width:max-content;border-radius:999px;background:#fff;color:#111;padding:9px 15px;box-shadow:none;}
.ad-preview-bottom p{margin:0;font-size:14px;line-height:1.25;font-weight:700;}
.ad-preview-bottom small{color:rgba(255,255,255,.72);font-weight:800;}
.ad-feed-preview{border-radius:24px;background:#fff;color:#111;border:1px solid var(--admin-line);box-shadow:0 22px 58px rgba(25,30,44,.13);overflow:hidden;}
.ad-feed-preview.hidden,.ad-phone-preview.hidden{display:none;}
.fb-head{display:flex;gap:10px;align-items:center;padding:14px;}
.fb-avatar{width:42px;height:42px;border-radius:999px;background:#111;color:#fff;font-size:11px;font-weight:900;display:flex;align-items:center;justify-content:center;}
.fb-head small{display:block;color:#697080;font-weight:700;}
.ad-feed-preview p{padding:0 14px;margin:0 0 12px;font-weight:700;line-height:1.3;}
.fb-artwork{height:290px;background:radial-gradient(circle at 24% 20%,rgba(239,35,60,.95),transparent 34%),linear-gradient(135deg,#111118,#ef233c);display:flex;align-items:center;justify-content:center;color:#fff;font-size:80px;font-weight:900;}
.fb-linkbar{display:flex;justify-content:space-between;align-items:center;gap:10px;background:#f1f2f5;padding:13px;}
.fb-linkbar small{display:block;text-transform:uppercase;color:#656b78;font-size:11px;font-weight:800;}
.fb-linkbar strong{display:block;font-size:15px;line-height:1.1;}
.fb-linkbar button{box-shadow:none;background:#e5e7eb;color:#111;border-radius:8px;padding:8px 12px;}
.ad-checklist{background:#fff;border:1px solid var(--admin-line);border-radius:24px;padding:18px;box-shadow:0 18px 42px rgba(25,30,44,.08);}
.ad-checklist h3{color:#111118;font-size:22px;margin-bottom:10px;}
.ad-checklist ul{margin:0;padding-left:18px;color:#727787;font-weight:800;line-height:1.7;}
.ads-export-grid .export-section{margin-bottom:14px;}
.notice.error{border-color:rgba(220,38,38,.35);background:rgba(220,38,38,.08);color:#b91c1c;}
@media(max-width:980px){.campaign-layout{grid-template-columns:1fr}.campaign-preview-panel{position:static}.ad-phone-preview{height:580px;max-width:350px;margin:auto}.ads-intro-grid{grid-template-columns:1fr}.campaign-detail-grid{grid-template-columns:1fr}.placement-grid,.promo-type-grid,.form-row.three-cols{grid-template-columns:1fr}}
@media(max-width:820px){.campaign-type-badge{width:64px;height:30px;font-size:10px}.campaign-summary{gap:10px}.ad-step-card{padding:16px;border-radius:22px}.campaign-layout{gap:16px}.ad-step-head h2{font-size:24px}.ad-phone-preview{height:540px}.fb-artwork{height:230px}}


/* Phase 2.1 - Ads Campaign extended sections */
.ad-video-current{border:1px solid rgba(17,24,39,.10);background:#fff;border-radius:16px;padding:12px 14px;margin-bottom:12px;color:#111827;font-weight:800;word-break:break-word;}
.ad-video-current a{color:#ef233c;text-decoration:none;}
.ad-video-upload{margin-top:10px;}
.ad-step-card textarea#interests,.ad-step-card textarea#countries_custom{min-height:96px;resize:vertical;line-height:1.35;}
.campaign-builder-form select{appearance:auto;}
.campaign-detail-grid .copybox{min-height:44px;}
.ad-step-head span{box-shadow:0 10px 24px rgba(239,35,60,.18);}
@media(max-width:820px){.ad-video-current{font-size:13px}.campaign-detail-grid{gap:10px}.campaign-builder-form textarea{font-size:14px}}

/* Phase 2.2 - Multi video, all previews and input suffixes */
.ad-video-list{margin:8px 0 0;padding-left:22px;color:#111827;font-weight:800;line-height:1.55;}
.suffix-input{display:flex;align-items:center;border:1px solid var(--admin-line);border-radius:16px;background:#fff;overflow:hidden;box-shadow:0 8px 22px rgba(25,30,44,.04);}
.suffix-input input{border:0!important;border-radius:0!important;box-shadow:none!important;background:#fff!important;min-width:0;}
.suffix-input span{flex:0 0 auto;padding:0 14px;color:#111118;font-size:14px;font-weight:900;border-left:1px solid var(--admin-line);height:42px;display:flex;align-items:center;background:#f8f9fc;}
.preview-section-title{background:#fff;border:1px solid var(--admin-line);border-radius:24px;padding:16px 18px;box-shadow:0 18px 42px rgba(25,30,44,.08);}
.preview-section-title h3{margin:0 0 4px;color:#111118;font-size:24px;}
.preview-section-title p{margin:0;color:#727787;font-weight:700;line-height:1.3;}
.preview-grid-all{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.mini-ad-preview{background:#fff;color:#111;border:1px solid var(--admin-line);border-radius:22px;overflow:hidden;box-shadow:0 18px 42px rgba(25,30,44,.08);min-height:220px;display:flex;flex-direction:column;}
.mini-ad-preview>span{display:block;padding:10px 12px;font-size:12px;font-weight:900;color:#ef233c;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--admin-line);}
.mini-video{height:145px;background:radial-gradient(circle at 26% 18%,rgba(239,35,60,.95),transparent 32%),radial-gradient(circle at 72% 22%,rgba(255,255,255,.34),transparent 24%),linear-gradient(145deg,#111118,#ef233c 58%,#050507);color:#fff;display:flex;align-items:center;justify-content:center;font-size:52px;font-weight:900;position:relative;overflow:hidden;}
.mini-ad-preview.story .mini-video,.mini-ad-preview.reels .mini-video{height:245px;}
.mini-video:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.42));}
.mini-video b{position:relative;z-index:1;text-shadow:0 10px 28px rgba(0,0,0,.35);}
.mini-feed-head{display:flex;align-items:center;gap:8px;padding:10px 12px 0;font-size:13px;}
.mini-feed-head i{width:28px;height:28px;border-radius:999px;background:#111;color:#fff;font-style:normal;font-size:9px;font-weight:900;display:flex;align-items:center;justify-content:center;}
.mini-feed-head strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mini-ad-preview p{font-size:12px;line-height:1.25;font-weight:800;margin:9px 12px 10px;color:#222;}
.mini-ad-preview.story p,.mini-ad-preview.reels p{margin-top:auto;color:#fff;background:linear-gradient(135deg,#111,#2a2a32);border-radius:12px;padding:9px;}
.mini-ad-preview button{align-self:flex-start;margin:0 12px 12px;border-radius:999px;padding:8px 12px;font-size:12px;box-shadow:none;background:#111;color:#fff;}
.mini-linkbar{margin-top:auto;background:#f1f2f5;padding:10px 12px;display:flex;gap:8px;align-items:center;justify-content:space-between;}
.mini-linkbar strong{font-size:12px;line-height:1.1;}
.mini-linkbar button{margin:0;background:#e5e7eb;color:#111;border-radius:9px;white-space:nowrap;}
.placement-grid label input:checked + span{font-weight:900;}
@media(max-width:1180px){.preview-grid-all{grid-template-columns:1fr}.mini-ad-preview.story .mini-video,.mini-ad-preview.reels .mini-video{height:220px}}
@media(max-width:980px){.preview-grid-all{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.preview-grid-all{grid-template-columns:1fr}.mini-ad-preview.story .mini-video,.mini-ad-preview.reels .mini-video{height:240px}.suffix-input span{height:40px;padding:0 11px;font-size:13px}}

/* Phase 2.3 - Hypeddit-style single large ad preview */
.placement-preview-tabs{border-radius:24px;flex-wrap:wrap;gap:7px;}
.placement-preview-tabs button{flex:1 1 31%;font-size:12px;line-height:1.05;min-height:42px;padding:9px 10px;}
.ad-preview-stage{background:#fff;border:1px solid var(--admin-line);border-radius:28px;padding:16px;box-shadow:0 22px 58px rgba(25,30,44,.13);}
.ad-preview-large{height:660px;max-width:360px;margin:0 auto;border:8px solid #111118;border-radius:36px;background:#050507;color:#fff;position:relative;overflow:hidden;box-shadow:0 28px 80px rgba(0,0,0,.28);}
.ad-preview-topbar{position:absolute;top:14px;left:16px;right:16px;z-index:5;font-size:18px;font-weight:900;letter-spacing:-.03em;text-shadow:0 3px 20px rgba(0,0,0,.45);}
.ad-preview-media{position:absolute;inset:0;overflow:hidden;background:#07070a;}
.ad-preview-video{width:100%;height:100%;object-fit:cover;display:block;background:#000;}
.ad-preview-artwork{position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(239,35,60,.95),transparent 30%),radial-gradient(circle at 70% 30%,rgba(255,255,255,.26),transparent 24%),linear-gradient(160deg,#111118,#ef233c 55%,#050507);display:flex;align-items:center;justify-content:center;font-size:96px;font-weight:900;}
.ad-preview-gradient{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.04) 35%,rgba(0,0,0,.72));pointer-events:none;}
.ad-preview-side-icons{position:absolute;right:13px;bottom:118px;z-index:5;display:grid;gap:16px;text-align:center;font-size:23px;font-weight:900;text-shadow:0 3px 18px rgba(0,0,0,.5);}
.ad-preview-content{position:absolute;left:18px;right:54px;bottom:26px;z-index:6;display:grid;gap:8px;text-shadow:0 2px 18px rgba(0,0,0,.45);}
.ad-preview-profile{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap;}
.ad-preview-avatar{width:31px;height:31px;border-radius:999px;background:#fff;color:#111;display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:900;text-shadow:none;}
.ad-preview-profile strong{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:170px;}
.ad-preview-profile small{font-size:11px;opacity:.78;font-weight:800;}
.ad-preview-content p{margin:0;font-size:14px;line-height:1.28;font-weight:700;max-height:72px;overflow:hidden;}
.ad-preview-content button{width:max-content;border-radius:999px;background:#fff;color:#111;padding:9px 15px;font-size:13px;font-weight:900;box-shadow:none;}
.ad-preview-feed-linkbar{display:none;position:absolute;left:0;right:0;bottom:0;z-index:7;background:#f1f2f5;color:#111;padding:13px;align-items:center;justify-content:space-between;gap:10px;text-shadow:none;}
.ad-preview-feed-linkbar small{display:block;text-transform:uppercase;color:#656b78;font-size:11px;font-weight:800;}
.ad-preview-feed-linkbar strong{display:block;font-size:15px;line-height:1.1;}
.ad-preview-feed-linkbar button{box-shadow:none;background:#e5e7eb;color:#111;border-radius:9px;padding:8px 12px;font-size:12px;white-space:nowrap;}
.ad-preview-large.is-feed{height:560px;max-width:390px;border-radius:26px;border-width:1px;background:#fff;color:#111;box-shadow:0 24px 65px rgba(25,30,44,.18);}
.ad-preview-large.is-feed .ad-preview-topbar{position:relative;top:auto;left:auto;right:auto;color:#111;text-shadow:none;padding:14px 14px 0;font-size:15px;}
.ad-preview-large.is-feed .ad-preview-media{position:relative;height:330px;margin-top:14px;}
.ad-preview-large.is-feed .ad-preview-side-icons{display:none;}
.ad-preview-large.is-feed .ad-preview-content{position:relative;left:auto;right:auto;bottom:auto;padding:12px 14px 10px;color:#111;text-shadow:none;display:flex;flex-direction:column;}
.ad-preview-large.is-feed .ad-preview-avatar{background:#111;color:#fff;}
.ad-preview-large.is-feed .ad-preview-profile small{color:#6b7280;opacity:1;}
.ad-preview-large.is-feed .ad-preview-content button{display:none;}
.ad-preview-large.is-feed .ad-preview-feed-linkbar{display:flex;}
.ad-preview-large.is-feed .ad-preview-gradient{background:linear-gradient(180deg,rgba(0,0,0,.02),rgba(0,0,0,.12));}
.ad-preview-large.is-story .ad-preview-topbar:after{content:'Sponsored';float:right;font-size:12px;opacity:.75;margin-top:4px;}
.ad-preview-large.is-story .ad-preview-side-icons{display:none;}
.ad-preview-large.is-story .ad-preview-content{right:18px;bottom:24px;text-align:center;align-items:center;}
.ad-preview-large.is-story .ad-preview-profile{justify-content:center;}
.ad-preview-large.is-story .ad-preview-content p{display:none;}
.ad-preview-large.is-facebook .ad-preview-topbar{font-size:16px;}
.ad-preview-large.is-facebook .ad-preview-content button,.ad-preview-large.is-facebook .ad-preview-feed-linkbar button{background:#1877f2;color:#fff;}
.preview-grid-all,.mini-ad-preview{display:none!important;}
@media(max-width:980px){.placement-preview-tabs button{flex:1 1 30%;}.ad-preview-large{height:610px;}.ad-preview-large.is-feed{height:540px;}}
@media(max-width:560px){.ad-preview-stage{padding:12px;border-radius:24px}.placement-preview-tabs button{flex:1 1 46%;font-size:11px;min-height:40px}.ad-preview-large{height:580px;max-width:330px;border-radius:32px}.ad-preview-large.is-feed{height:520px;max-width:330px}.ad-preview-large.is-feed .ad-preview-media{height:285px}.ad-preview-content{left:15px;right:48px}.ad-preview-content p{font-size:13px}.ad-preview-side-icons{right:10px}}

/* Phase 2.4 - Immediate AD video import, preview, delete and ordering */
.ad-video-upload-live{align-items:center;margin-bottom:12px;}
.ad-video-upload-progress{border:1px solid rgba(17,24,39,.10);background:#fff;border-radius:16px;padding:12px 14px;margin:10px 0;color:#111827;font-weight:800;}
.ad-video-upload-progress>div:first-child{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:9px;}
.ad-video-progress-track{height:9px;border-radius:999px;background:#eef0f5;overflow:hidden;}
.ad-video-progress-track span{display:block;height:100%;width:0;background:linear-gradient(135deg,#ef233c,#111118);border-radius:999px;transition:width .18s ease;}
.ad-video-error{border:1px solid rgba(220,38,38,.26);background:#fff5f5;color:#b42318;border-radius:16px;padding:11px 13px;font-weight:900;margin:10px 0;}
.live-video-list{margin-top:14px;}
.live-video-list.is-empty .ad-video-list{display:none;}
.live-video-list.is-empty:after{content:'Nessun video importato. Carica almeno 1 video per salvare la campagna.';display:block;margin-top:9px;color:#727787;font-size:13px;font-weight:800;}
.sortable-video-list{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:10px;}
.ad-video-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(17,24,39,.10);background:#f8f9fc;border-radius:16px;padding:10px 12px;}
.ad-video-item-meta{display:flex;align-items:center;gap:10px;min-width:0;}
.ad-video-number{width:28px;height:28px;border-radius:999px;background:#111118;color:#fff;font-size:12px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;flex:0 0 28px;}
.ad-video-item a{color:#111118!important;text-decoration:none!important;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:320px;}
.ad-video-actions{display:flex;align-items:center;justify-content:flex-end;gap:7px;flex-wrap:wrap;}
.ad-video-actions select{width:auto!important;min-width:86px!important;border-radius:999px!important;padding:7px 10px!important;font-size:12px!important;font-weight:900!important;background:#fff!important;}
.mini-btn{border:0!important;border-radius:999px!important;background:#fff!important;color:#111118!important;box-shadow:none!important;padding:7px 10px!important;font-size:12px!important;font-weight:900!important;line-height:1!important;}
.mini-btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(25,30,44,.08)!important;}
.mini-btn:disabled{opacity:.35;cursor:not-allowed;transform:none!important;}
.mini-btn.danger{background:#fff0f0!important;color:#dc2626!important;border:1px solid rgba(220,38,38,.18)!important;}
@media(max-width:820px){.ad-video-item{align-items:flex-start;flex-direction:column}.ad-video-actions{width:100%;justify-content:flex-start}.ad-video-item a{max-width:260px}.ad-video-actions select{flex:1}.mini-btn{padding:8px 12px!important}}

/* Phase 2.5 - Spotify-only campaign smartlink + video preview fix */
.spotify-check-box{margin:12px 0 14px;border:1px solid rgba(17,24,39,.10);background:#f8f9fc;border-radius:16px;padding:12px 14px;color:#111827;font-weight:800;line-height:1.35;display:grid;gap:4px;}
.spotify-check-box strong{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:#ef233c;}
.spotify-check-box span{font-size:13px;color:#687080;font-weight:800;}
.spotify-check-box.is-loading{background:#fff8e7;border-color:rgba(245,158,11,.25);}
.spotify-check-box.is-ok{background:#ecfdf5;border-color:rgba(16,185,129,.28);}
.spotify-check-box.is-error{background:#fff5f5;border-color:rgba(220,38,38,.28);}
.spotify-check-box.is-ok span{color:#047857;}.spotify-check-box.is-error span{color:#b42318;}
.auto-smartlink-note{border:1px solid rgba(29,185,84,.22);background:linear-gradient(135deg,rgba(29,185,84,.08),rgba(255,255,255,.96));border-radius:18px;padding:13px 15px;margin-bottom:14px;color:#111827;}
.auto-smartlink-note strong{display:block;font-size:15px;color:#111827;margin-bottom:3px;}.auto-smartlink-note p{margin:0;color:#687080;font-weight:800;line-height:1.35;}
.campaign-cover-preview{display:block;width:96px;height:96px;object-fit:cover;border-radius:18px;margin-top:10px;box-shadow:0 14px 32px rgba(25,30,44,.16);}
.ad-preview-video:not([hidden]){display:block!important;visibility:visible!important;opacity:1!important;}


/* Phase 2.6 - preview refresh action */
.preview-section-title-action{display:flex;align-items:center;justify-content:space-between;gap:14px;}
.preview-section-title-action h3{margin:0!important;}
.preview-refresh-btn{white-space:nowrap;padding:10px 15px!important;font-size:13px!important;box-shadow:0 14px 30px rgba(239,35,60,.18)!important;}
.preview-refresh-btn.is-updated{background:linear-gradient(135deg,#16a34a,#15803d)!important;}
.ad-preview-large.is-preview-pulse{animation:previewPulseRefresh .55s ease both;}
@keyframes previewPulseRefresh{0%{transform:scale(1)}45%{transform:scale(1.012)}100%{transform:scale(1)}}
@media(max-width:560px){.preview-section-title-action{align-items:stretch;flex-direction:column}.preview-refresh-btn{width:100%;}}

/* Phase 2.7 - Focus track toggle */
.focus-track-wrap{transition:opacity .18s ease;}

/* Phase 2.14 - Spotify playlist deep-link redirect */
.spotify-redirect-body{margin:0;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(circle at 20% 0%,rgba(29,185,84,.22),transparent 34%),linear-gradient(135deg,#050507,#101018 48%,#09090b);color:#fff;font-family:'Titillium Web',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif}.spotify-redirect-card{width:min(100%,430px);text-align:center;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.08);box-shadow:0 28px 90px rgba(0,0,0,.32);backdrop-filter:blur(18px);border-radius:30px;padding:34px 24px}.spotify-redirect-logo{width:58px;height:58px;border-radius:999px;background:#1DB954;color:#06140a;display:inline-flex;align-items:center;justify-content:center;font-weight:900;margin-bottom:16px;box-shadow:0 18px 40px rgba(29,185,84,.28)}.spotify-redirect-card h1{font-size:35px;margin:0 0 8px;letter-spacing:-.04em}.spotify-redirect-card p{margin:0 auto 20px;max-width:330px;color:rgba(255,255,255,.72);font-weight:700;line-height:1.35}.spotify-redirect-loader{width:100%;height:8px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden;margin:0 0 20px}.spotify-redirect-loader span{display:block;width:38%;height:100%;border-radius:999px;background:#1DB954;animation:oumSpotifyRedirectLoad 1.05s ease-in-out infinite alternate}.spotify-redirect-actions{display:grid;gap:9px}.spotify-redirect-actions .btn{display:flex;align-items:center;justify-content:center;text-decoration:none}.spotify-redirect-actions .btn.secondary{background:#fff!important;color:#101014!important}.spotify-redirect-actions .btn.ghost{background:transparent!important;border:1px solid rgba(255,255,255,.18)!important;color:#fff!important;box-shadow:none!important}@keyframes oumSpotifyRedirectLoad{from{transform:translateX(-20%);opacity:.55}to{transform:translateX(180%);opacity:1}}


/* Phase 3.0 - Meta Ads Direct Publishing */
.meta-settings-card { padding: 26px; }
.meta-safe-check { display:flex; align-items:center; gap:10px; margin:18px 0; padding:14px 16px; border-radius:18px; background:rgba(20,20,20,.035); color:var(--text); font-weight:700; }
.meta-safe-check input { width:auto; transform:scale(1.15); }
.meta-assets-grid { grid-template-columns: repeat(3,minmax(0,1fr)); margin-top:22px; }
.meta-mini-list { display:grid; gap:10px; margin-top:14px; }
.meta-mini-list > div { padding:12px 14px; border-radius:16px; background:rgba(255,255,255,.82); border:1px solid rgba(0,0,0,.06); }
.meta-mini-list strong { display:block; font-size:15px; }
.meta-mini-list small { display:block; color:var(--muted); margin-top:4px; line-height:1.35; word-break:break-word; }
.meta-help-card { margin-top:22px; padding:24px; }
@media (max-width: 860px){ .meta-assets-grid { grid-template-columns:1fr; } }

/* Phase 3.0.3 - Mobile hamburger admin menu */
.mobile-menu-toggle{display:none;appearance:none;border:0;background:#fff;color:#121219;width:44px;height:44px;border-radius:14px;box-shadow:0 14px 34px rgba(24,28,42,.10);align-items:center;justify-content:center;flex-direction:column;gap:5px;padding:0;cursor:pointer;flex:0 0 auto;}
.mobile-menu-toggle span{display:block;width:20px;height:2px;border-radius:999px;background:#121219;transition:transform .18s ease,opacity .18s ease;}
.mobile-menu-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.mobile-menu-toggle.is-open span:nth-child(2){opacity:0;}
.mobile-menu-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media(max-width:640px){
  body:not(.fanlink-body) .eyebrow{margin-top:30px;}
  body:not(.fanlink-body) .topbar{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;}
  body:not(.fanlink-body) .mobile-menu-toggle{display:inline-flex;justify-self:end;}
  body:not(.fanlink-body) .nav{grid-column:1 / -1;display:none;width:100%;grid-template-columns:1fr;gap:8px;margin-top:4px;}
  body:not(.fanlink-body) .nav.is-open{display:grid;animation:adminMobileMenuIn .16s ease both;}
  body:not(.fanlink-body) .nav .btn{width:100%;text-align:center;}
}
@keyframes adminMobileMenuIn{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}

/* Phase 3.0.8 - Live Meta interests search */
.meta-interest-live-box{margin:14px 0 16px;padding:14px;border:1px solid rgba(15,23,42,.08);border-radius:18px;background:linear-gradient(180deg,#fff,#fafafa);box-shadow:0 14px 34px rgba(15,23,42,.05);}
.meta-interest-search-row{display:flex;gap:10px;align-items:center;margin-top:8px;}
.meta-interest-search-row input{flex:1;min-width:0;}
.meta-interest-status{margin-top:9px;color:var(--muted);font-size:13px;line-height:1.35;}
.meta-interest-results{margin-top:12px;display:grid;gap:8px;max-height:330px;overflow:auto;padding-right:3px;}
.meta-interest-result{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:10px 11px;border:1px solid rgba(15,23,42,.08);border-radius:14px;background:#fff;}
.meta-interest-info{display:grid;gap:3px;min-width:0;}
.meta-interest-info strong{font-size:14px;color:var(--ink);}
.meta-interest-info span{font-size:12px;color:var(--muted);}
.meta-interest-info small{font-size:11px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:520px;}
.meta-interest-empty{padding:12px;border-radius:14px;background:#fff7ed;color:#9a3412;font-size:13px;border:1px solid rgba(251,146,60,.25);}
@media(max-width:640px){.meta-interest-search-row{display:grid}.meta-interest-result{align-items:flex-start}.meta-interest-info small{max-width:230px}}

/* Phase 3.0.11 - Meta Advantage Audience */
.meta-optimization-options{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:14px 0}
.meta-optimization-option{display:flex;gap:12px;align-items:flex-start;padding:16px;border:1px solid rgba(15,23,42,.10);border-radius:20px;background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 10px 28px rgba(15,23,42,.06);cursor:pointer}
.meta-optimization-option input{margin-top:4px;accent-color:#111827}
.meta-optimization-option strong{display:block;color:#111827;font-size:15px;margin-bottom:4px}
.meta-optimization-option small{display:block;color:#64748b;line-height:1.35}
@media(max-width:760px){.meta-optimization-options{grid-template-columns:1fr}}

/* Phase 3.0.13 - Impact loading overlay for Meta operations */
.meta-loading-overlay{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(18px);
}
.meta-loading-overlay.is-visible{display:flex;}
.meta-loading-card{
  width:min(520px,100%);
  text-align:center;
  border:1px solid rgba(220,38,38,.16);
  border-radius:32px;
  padding:34px 28px 28px;
  background:linear-gradient(145deg,#ffffff 0%,#fff7f7 46%,#fff 100%);
  box-shadow:0 28px 90px rgba(127,29,29,.22);
  position:relative;
  overflow:hidden;
}
.meta-loading-card:before{
  content:"";
  position:absolute;
  inset:-80px -60px auto auto;
  width:220px;
  height:220px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(239,68,68,.24),rgba(239,68,68,0) 68%);
}
.meta-loading-orb{
  width:82px;
  height:82px;
  margin:0 auto 18px;
  border-radius:999px;
  background:conic-gradient(from 0deg,#ef4444,#111827,#ef4444);
  animation:oumMetaSpin 1.05s linear infinite;
  position:relative;
  box-shadow:0 18px 40px rgba(239,68,68,.25);
}
.meta-loading-orb:after{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:999px;
  background:#fff;
}
.meta-loading-card h2{
  margin:8px 0 8px;
  font-size:clamp(1.55rem,4vw,2.15rem);
  line-height:1.02;
}
.meta-loading-card p{
  margin:0 auto;
  max-width:430px;
  color:var(--muted);
  font-weight:600;
}
.meta-loading-steps{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  margin-top:22px;
}
.meta-loading-steps span{
  padding:8px 11px;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.02em;
}
@keyframes oumMetaSpin{to{transform:rotate(360deg)}}
@media(max-width:640px){
  .meta-loading-card{padding:30px 20px 24px;border-radius:26px;}
  .meta-loading-orb{width:70px;height:70px;}
}

/* Phase 3.0.19 - Optimization progress + manual recommendations */
.campaign-summary{grid-template-columns:auto minmax(0,1fr) minmax(180px,260px) auto!important;}
.campaign-summary-optimization{display:flex;flex-direction:column;gap:7px;align-items:stretch;min-width:180px;padding:9px 11px;border:1px solid rgba(17,24,39,.08);border-radius:16px;background:#f8fafc;box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
.summary-opt-top{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;line-height:1.1;color:#111827;}
.summary-opt-top strong{font-size:18px;font-weight:950;letter-spacing:-.04em;}
.summary-opt-top em{font-style:normal;color:#667085;font-weight:800;text-align:right;}
.summary-opt-bar,.optimization-progress{height:9px;border-radius:999px;background:#e5e7eb;overflow:hidden;display:block;position:relative;}
.summary-opt-bar i,.optimization-progress i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#ef233c,#111827);box-shadow:0 7px 18px rgba(239,35,60,.22);transition:width .45s ease;}
.campaign-summary-optimization.is-auto .summary-opt-bar i{background:linear-gradient(90deg,#16a34a,#111827)}
.campaign-summary-optimization.is-error .summary-opt-bar i{background:linear-gradient(90deg,#ef4444,#991b1b)}
.campaign-summary-optimization.is-manual .summary-opt-bar i{background:linear-gradient(90deg,#f59e0b,#111827)}
.campaign-optimization-panel{margin-top:16px;padding:18px;border:1px solid var(--admin-line);border-radius:24px;background:linear-gradient(145deg,#fff,#f8fafc);box-shadow:0 18px 50px rgba(24,30,44,.07)}
.optimization-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:14px;}
.optimization-head h3{margin:8px 0 4px;font-size:24px;line-height:1.05;}
.optimization-score{flex:0 0 auto;min-width:128px;text-align:center;padding:14px;border-radius:22px;background:#111827;color:#fff;box-shadow:0 18px 40px rgba(17,24,39,.15)}
.optimization-score strong{display:block;font-size:36px;line-height:.9;letter-spacing:-.06em;}
.optimization-score span{display:block;margin-top:7px;font-size:12px;font-weight:800;color:rgba(255,255,255,.78)}
.optimization-recommendations{display:grid;gap:10px;margin-top:14px;}
.optimization-rec{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:13px;border:1px solid rgba(17,24,39,.08);border-radius:18px;background:#fff;}
.optimization-rec strong{display:block;color:#111827;font-size:15px;}
.optimization-rec p{margin:4px 0 5px;color:#667085;font-weight:600;line-height:1.35;}
.optimization-rec small{color:#ef233c;font-weight:900;text-transform:uppercase;letter-spacing:.06em;}
.optimization-rec.is-applied{background:#ecfdf5;border-color:rgba(16,185,129,.24)}
.optimization-applied,.optimization-manual{display:inline-flex;align-items:center;justify-content:center;min-width:82px;padding:9px 11px;border-radius:999px;font-size:12px;font-weight:900;}
.optimization-applied{background:#dcfce7;color:#166534}.optimization-manual{background:#fef3c7;color:#92400e}
.meta-loading-percent{margin:20px auto 2px;max-width:360px;display:grid;gap:10px;}
.meta-loading-percent strong{font-size:34px;line-height:1;font-weight:950;letter-spacing:-.06em;color:#111827;}
.meta-loading-percent div{height:11px;border-radius:999px;background:#e5e7eb;overflow:hidden;box-shadow:inset 0 1px 2px rgba(0,0,0,.06)}
.meta-loading-percent i{display:block;width:0;height:100%;border-radius:999px;background:linear-gradient(90deg,#ef233c,#111827);transition:width .6s ease;}
@media(max-width:820px){
  .campaign-summary{grid-template-columns:auto minmax(0,1fr) auto!important;}
  .campaign-summary-optimization{grid-column:1/-1;min-width:0;width:100%;}
  .optimization-head{flex-direction:column;}.optimization-score{width:100%;}.optimization-rec{grid-template-columns:1fr;}.optimization-rec .btn{width:100%;}
}


/* Phase 3.2.1 - Restore campaign accordion dropdown controls */
.campaign-item > .campaign-summary{cursor:pointer;}
.campaign-chevron{display:inline-flex!important;align-items:center;justify-content:center;gap:7px;min-width:74px;height:36px;padding:0 12px;border-radius:999px;background:#f3f4f6;color:#111827;font-size:12px;font-weight:900;line-height:1;transition:transform .18s ease,background .18s ease,color .18s ease;}
.campaign-toggle-label{display:inline-block;text-transform:uppercase;letter-spacing:.04em;font-size:10px;}
.campaign-toggle-icon{display:inline-block;font-size:16px;line-height:1;transition:transform .18s ease;}
.release-item[open] .campaign-chevron{background:#121219;color:#fff;transform:none;}
.release-item[open] .campaign-toggle-icon{transform:rotate(180deg);}
.campaign-details{display:block;}
@media(max-width:640px){.campaign-chevron{min-width:66px;height:34px;padding:0 10px}.campaign-toggle-label{font-size:9px}}
/* Phase 3.3 - real Meta performance / optimization score */
.optimization-live-note{margin:12px 0 14px;padding:12px 14px;border-radius:18px;background:#f8fafc;border:1px solid rgba(15,23,42,.08);display:grid;gap:4px;color:#475569;font-weight:700;line-height:1.35}
.optimization-live-note strong{color:#111827;font-size:13px}.optimization-live-note span{font-size:13px;color:#64748b}
.optimization-kpis{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:12px 0 14px}
.optimization-kpis span{display:flex;flex-direction:column;gap:4px;padding:12px;border-radius:18px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 10px 28px rgba(15,23,42,.05)}
.optimization-kpis strong{font-size:18px;color:#111827;letter-spacing:-.03em}.optimization-kpis em{font-style:normal;color:#64748b;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}
.optimization-history{margin-top:14px;padding:14px;border-radius:20px;background:linear-gradient(145deg,#111827,#0f172a);color:#fff;display:grid;gap:6px}
.optimization-history strong{font-size:13px;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.8)}
.optimization-history p{margin:0;color:rgba(255,255,255,.82);font-size:13px;font-weight:700}.optimization-history span{color:#fff}
@media(max-width:900px){.optimization-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.optimization-kpis{grid-template-columns:1fr}}


.meta-cron-box{
  margin:22px 0 6px;
  padding:22px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(247,248,252,.96));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 18px 44px rgba(15,23,42,.08);
}
.meta-cron-box h2{margin:4px 0 8px;font-size:22px;letter-spacing:-.02em}
.meta-cron-box code{font-size:12px;background:#111827;color:#fff;padding:3px 6px;border-radius:8px;white-space:normal;word-break:break-all}
.meta-cron-box input[readonly]{font-size:13px;background:#f8fafc;color:#0f172a;cursor:pointer}
@media(max-width:640px){.meta-cron-box{padding:18px;border-radius:20px}.meta-cron-box h2{font-size:20px}}

.meta-auto-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  font-weight:800;
  font-size:12px;
  letter-spacing:.02em;
  color:#166534;
  background:linear-gradient(135deg,#dcfce7,#bbf7d0);
  border:1px solid rgba(22,101,52,.18);
  box-shadow:0 10px 24px rgba(22,101,52,.10);
}


/* Phase 3.3.5 - Safe campaign deletion */
.campaign-delete-form{
  align-items:center;
  gap:8px;
}
.delete-mode-select{
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  color:#111827;
  border-radius:999px;
  padding:10px 14px;
  font-family:inherit;
  font-weight:700;
  min-height:40px;
  box-shadow:0 8px 22px rgba(15,23,42,.06);
}
@media(max-width:640px){
  .campaign-delete-form{width:100%; align-items:stretch;}
  .delete-mode-select{width:100%; border-radius:16px;}
  .campaign-delete-form .btn{width:100%;}
}


/* Phase 3.3.8 - Editable post main copy field */
.post-copy-callout{margin:14px 0 16px!important;padding:18px!important;border-radius:22px!important;border:1px solid rgba(239,35,60,.22)!important;background:linear-gradient(135deg,rgba(239,35,60,.075),rgba(255,255,255,.96))!important;box-shadow:0 16px 42px rgba(25,30,44,.08)!important;position:relative!important;z-index:2!important;}
.post-copy-callout label{margin:0 0 6px!important;font-size:17px!important;font-weight:900!important;color:#121219!important;display:flex!important;align-items:center!important;gap:8px!important;}
.post-copy-callout label:before{content:"✍️";font-size:18px;}
.post-copy-callout p{margin:0 0 10px!important;color:#5f6472!important;line-height:1.35!important;font-weight:700!important;}
.post-copy-callout strong{color:#121219!important;}
.post-copy-input{width:100%!important;min-height:54px!important;font-size:17px!important;font-weight:800!important;line-height:1.25!important;background:#fff!important;color:#111827!important;border:1px solid rgba(239,35,60,.32)!important;border-radius:16px!important;padding:14px 16px!important;display:block!important;visibility:visible!important;opacity:1!important;pointer-events:auto!important;user-select:text!important;position:relative!important;z-index:3!important;}
.post-copy-input:focus{border-color:rgba(239,35,60,.75)!important;box-shadow:0 0 0 4px rgba(239,35,60,.10)!important;outline:none!important;}
.post-copy-hint{display:block;margin-top:8px;color:#6b7280;font-weight:800;line-height:1.35;}
@media(max-width:820px){.post-copy-callout{padding:15px!important;border-radius:18px!important}.post-copy-input{min-height:56px!important;font-size:16px!important}}


/* Phase 3.3.9 - Meta Business guide card + guide page */
.ads-intro-grid-three{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
}
.ads-guide-card{
  position:relative;
  display:flex!important;
  flex-direction:column;
  justify-content:space-between;
  min-height:100%;
  text-decoration:none!important;
  color:inherit!important;
  overflow:hidden;
}
.ads-guide-card:before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:5px;
  background:linear-gradient(90deg,#111118,#ef233c,#f59e0b);
}
.ads-guide-card:hover{
  transform:translateY(-2px);
  box-shadow:0 26px 70px rgba(25,30,44,.13);
}
.ads-guide-card h2{margin-top:0;}
.ads-guide-cta{
  display:inline-flex;
  width:max-content;
  align-items:center;
  margin-top:14px;
  border-radius:999px;
  padding:9px 13px;
  background:#111118;
  color:#fff;
  font-weight:900;
  font-size:13px;
}
.meta-guide-layout{
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  gap:20px;
  align-items:start;
}
.meta-guide-nav{
  position:sticky;
  top:112px;
  display:grid;
  gap:9px;
  padding:18px!important;
  background-color: white;
  border-radius: 25px;
  }
}
.meta-guide-nav strong{
  color:#111118;
  font-size:18px;
  font-weight:900;
  letter-spacing:-.02em;
  margin-bottom:4px;
}
.meta-guide-nav a{
  display:block;
  text-decoration:none;
  color:#343844;
  font-weight:800;
  border:1px solid var(--admin-line);
  border-radius:14px;
  padding:10px 12px;
  background:#fff;
}
.meta-guide-nav a:hover{
  border-color:rgba(239,35,60,.32);
  color:#ef233c;
}
.meta-guide-main{
  display:grid;
  gap:18px;
  min-width:0;
}
.meta-guide-hero{
  background:radial-gradient(circle at 0% 0%,rgba(239,35,60,.12),transparent 36%),#fff!important;
}
.meta-guide-values{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}
.meta-guide-values span{
  display:inline-flex;
  border-radius:999px;
  padding:8px 11px;
  background:#f3f4f7;
  color:#111118;
  font-size:12px;
  font-weight:900;
}
.meta-guide-section{
  position:relative;
  padding-left:74px!important;
  scroll-margin-top:120px;
}
.meta-step{
  position:absolute;
  left:20px;
  top:22px;
  width:38px;
  height:38px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#ef233c,#111118);
  color:#fff;
  font-weight:900;
  box-shadow:0 14px 30px rgba(239,35,60,.18);
}
.meta-guide-section h2{
  margin-bottom:8px;
}
.meta-guide-section h3{
  font-size:20px;
  margin-bottom:6px;
}
.meta-guide-section ul,
.meta-guide-section ol{
  margin:10px 0 0;
  padding-left:22px;
  color:#454a57;
  font-weight:700;
  line-height:1.58;
}
.meta-guide-section li + li{
  margin-top:4px;
}
.meta-guide-section code{
  display:inline-block;
  border-radius:8px;
  background:#f1f3f7;
  color:#111118;
  padding:2px 6px;
  font-weight:900;
  font-family:'Titillium Web',system-ui,sans-serif!important;
}
.meta-id-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-top:14px;
}
.meta-id-grid>div{
  border:1px solid var(--admin-line);
  border-radius:18px;
  background:#fafbfc;
  padding:14px;
}
.meta-id-grid p{
  margin:0;
  color:#5f6573;
  font-weight:700;
  line-height:1.35;
}
@media(max-width:980px){
  .ads-intro-grid-three{
    grid-template-columns:1fr!important;
  }
  .meta-guide-layout{
    grid-template-columns:1fr;
  }
  .meta-guide-nav{
    position:static;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .meta-guide-nav strong{
    grid-column:1/-1;
  }
}
@media(max-width:640px){
  .ads-guide-card{
    min-height:auto;
  }
  .meta-guide-nav{
    grid-template-columns:1fr;
  }
  .meta-guide-section{
    padding-left:18px!important;
    padding-top:74px!important;
    scroll-margin-top:24px;
  }
  .meta-step{
    left:18px;
    top:18px;
  }
  .meta-id-grid{
    grid-template-columns:1fr;
  }
}

/* Phase 3.3.10 - Meta cron terminal command boxes */
.cron-command-box{
  width:100%;
  min-height:92px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace!important;
  font-size:13px;
  line-height:1.42;
  resize:vertical;
  cursor:pointer;
  white-space:pre-wrap;
  overflow-wrap:anywhere;
}

/* Phase 3.3.11 - Smartlink Spotify Autofill */
.smartlink-autofill-card{border:1px solid rgba(239,35,60,.12);background:linear-gradient(180deg,#ffffff,#fbfbfd);}
.smartlink-autofill-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;}
.smartlink-autofill-head h2{margin-bottom:8px;}
.smartlink-autofill-head .btn{flex:0 0 auto;margin-top:4px;}
.smartlink-autofill-status{margin-bottom:0;}
.smartlink-autofill-status.is-loading strong{color:#b45309;}
.smartlink-autofill-status.is-ok strong{color:#047857;}
.smartlink-autofill-status.is-error strong{color:#b42318;}
@media(max-width:820px){.smartlink-autofill-head{display:grid;gap:12px}.smartlink-autofill-head .btn{width:100%;}}

.smartlink-autofill-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:end;margin:16px 0 14px;}
.smartlink-autofill-url-field label{display:block;margin-bottom:7px;}
.smartlink-autofill-url-field input{width:100%;}
.smartlink-autofill-row .btn{white-space:nowrap;margin-bottom:0;}
@media(max-width:820px){.smartlink-autofill-row{grid-template-columns:1fr}.smartlink-autofill-row .btn{width:100%;}}


/* Phase 3.3.16 - Spotify check genre interest suggestions readability fix */
.spotify-interest-suggestions{
  margin-top:12px;
  padding:14px;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid rgba(15,23,42,.14);
  box-shadow:0 12px 26px rgba(15,23,42,.06);
}
.spotify-interest-title{
  font-weight:800;
  color:#0f172a;
  margin-bottom:9px;
}
.spotify-interest-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
}
.spotify-interest-chip{
  appearance:none;
  border:1px solid rgba(15,23,42,.22) !important;
  background:#ffffff !important;
  color:#111827 !important;
  border-radius:999px;
  padding:8px 12px;
  font-family:inherit;
  font-size:13px;
  line-height:1.15;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 4px 12px rgba(15,23,42,.06);
}
.spotify-interest-chip:hover{
  transform:translateY(-1px);
  background:#fff7ed !important;
  color:#9a3412 !important;
  border-color:rgba(249,115,22,.45) !important;
  box-shadow:0 8px 18px rgba(15,23,42,.10);
}
.spotify-interest-add-all{ margin-bottom:8px; }
.spotify-interest-suggestions small{ display:block; color:#475569; line-height:1.35; }



/* Phase 3.4.1 - Smartlink origin badge */
.smartlink-origin-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-left:8px;
  padding:4px 9px;
  border-radius:999px;
  font-size:11px;
  line-height:1;
  font-weight:700;
  letter-spacing:.02em;
  vertical-align:middle;
  white-space:nowrap;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  color:#111827;
  box-shadow:0 6px 16px rgba(15,23,42,.06);
}
.smartlink-origin-badge.is-campaign{
  background:linear-gradient(135deg,#111827,#fb923c);
  color:#fff;
  border-color:rgba(251,146,60,.35);
}
.smartlink-origin-badge.is-classic{
  background:#ffffff;
  color:#374151;
}
.smartlink-origin-note{
  margin-top:10px;
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  color:#374151;
  box-shadow:0 10px 26px rgba(15,23,42,.05);
}
.smartlink-origin-note strong{
  display:inline-flex;
  white-space:nowrap;
  color:#111827;
}
.smartlink-origin-note span{
  display:block;
  color:#6b7280;
  line-height:1.35;
}
.smartlink-origin-note.is-campaign{
  border-color:rgba(251,146,60,.28);
  background:linear-gradient(135deg,rgba(255,247,237,.98),rgba(255,255,255,.98));
}
.smartlink-origin-note.is-campaign strong{color:#c2410c;}
@media(max-width:640px){
  .smartlink-origin-badge{margin-left:0;margin-top:6px;width:max-content;}
  .smartlink-origin-note{display:block;}
  .smartlink-origin-note span{margin-top:6px;}
}

/* Phase 3.5.1 - campaign delete cleanup note */
.delete-cleanup-note{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 10px;
  border:1px solid rgba(239,68,68,.22);
  border-radius:999px;
  background:rgba(239,68,68,.06);
  color:#991b1b;
  font-size:12px;
  font-weight:700;
}
.delete-cleanup-note:before{content:'🧹';}
@media(max-width:640px){.delete-cleanup-note{width:100%;justify-content:center;border-radius:14px;}}


/* Phase 3.6.0 - Spotify Listen Pixel Event */
.pixel-event-note{
  margin-top:14px;
  padding:14px 16px;
  border:1px solid rgba(245,137,58,.28);
  background:linear-gradient(135deg, rgba(255,255,255,.96), rgba(255,246,239,.98));
  border-radius:16px;
  display:flex;
  flex-direction:column;
  gap:5px;
  color:#1f1f24;
}
.pixel-event-note strong{font-weight:700;color:#111827;}
.pixel-event-note span{font-size:13px;line-height:1.45;color:#5b5f68;}
.pixel-event-note code,
.pixel-conversion-guide-card code{
  background:#fff;
  border:1px solid rgba(17,24,39,.10);
  border-radius:8px;
  padding:1px 6px;
  color:#111827;
}
.pixel-guide-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin:14px 0;
}
.pixel-guide-grid div{
  border:1px solid rgba(17,24,39,.08);
  background:#fff;
  border-radius:14px;
  padding:12px;
}
.pixel-guide-grid strong{display:block;color:#111827;margin-bottom:4px;}
.pixel-guide-grid small{display:block;color:#687083;line-height:1.35;}
@media(max-width:760px){.pixel-guide-grid{grid-template-columns:1fr;}}


/* Phase 3.6.1 - ListenClick Custom Conversion */
.pixel-conversion-status{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin:16px 0;
}
.pixel-conversion-status div{
  background:#fff;
  border:1px solid rgba(15,23,42,.12);
  border-radius:16px;
  padding:14px;
  box-shadow:0 10px 25px rgba(15,23,42,.05);
}
.pixel-conversion-status strong{
  display:block;
  color:#111827;
  font-weight:700;
  margin-bottom:5px;
}
.pixel-conversion-status small{
  display:block;
  color:#6b7280;
  word-break:break-word;
}
.pixel-conversion-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin:14px 0 6px;
}
.pixel-conversion-error{margin:12px 0;}
@media(max-width:760px){
  .pixel-conversion-status{grid-template-columns:1fr;}
}


/* Phase 3.8.0 - ListenClick Conversion Optimization Mode */
.meta-optimization-mode-box{margin:18px 0;padding:16px;border:1px solid rgba(245,128,32,.22);border-radius:18px;background:linear-gradient(135deg,rgba(255,247,239,.98),rgba(255,255,255,.96));}
.meta-mode-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:10px;}
.meta-mode-card{display:flex;gap:10px;align-items:flex-start;padding:13px;border:1px solid rgba(18,18,18,.1);border-radius:15px;background:#fff;cursor:pointer;}
.meta-mode-card input{margin-top:4px;}
.meta-mode-card strong{display:block;color:#191919;font-size:14px;margin-bottom:3px;}
.meta-mode-card small{display:block;color:#696969;line-height:1.35;}
.meta-mode-card.is-selected{border-color:#f58020;box-shadow:0 12px 28px rgba(245,128,32,.13);}
.meta-mode-badge{display:inline-flex;align-items:center;padding:5px 9px;border-radius:999px;background:#fff3e7;color:#9a4d00;font-weight:700;font-size:12px;margin-left:6px;}
@media(max-width:760px){.meta-mode-grid{grid-template-columns:1fr;}}

/* Phase 3.8.1 - visible Meta optimization selector */
.meta-optimization-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
.meta-optimization-option.is-selected{border-color:rgba(245,128,32,.55);box-shadow:0 12px 30px rgba(245,128,32,.14);background:linear-gradient(180deg,#fff7ed,#ffffff);}
.meta-optimization-mode-box small{display:block;color:#64748b;line-height:1.45;margin-top:5px;}
@media(max-width:760px){.meta-optimization-choice-grid{grid-template-columns:1fr;}}

/* Phase 3.8.2 - clearer Meta optimization choice */
.meta-optimization-choice-grid{gap:18px;}
.meta-optimization-option{position:relative;overflow:hidden;border-width:2px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;background:linear-gradient(145deg,#ffffff,#f8fafc);}
.meta-optimization-option:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(15,23,42,.10);}
.meta-optimization-option.is-selected{border-color:#f58020;background:linear-gradient(145deg,#fff7ed,#ffffff 62%,#fff);box-shadow:0 18px 44px rgba(245,128,32,.18);}
.meta-optimization-option.is-selected:after{content:'Selezionata';position:absolute;top:12px;right:12px;padding:5px 9px;border-radius:999px;background:#111827;color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em;}
.meta-optimization-option input{width:18px;height:18px;flex:0 0 auto;}
.meta-optimization-option strong{font-size:16px;}
.meta-optimization-option small{font-size:13px;}
.meta-optimization-option:nth-child(2).is-selected{background:linear-gradient(145deg,#fff7ed,#ffffff 50%,#eef2ff);}
.meta-optimization-mode-box{border-width:2px;}


/* Phase 3.8.3 - Meta optimization selector state + global account values */
.meta-optimization-option input:checked + span strong{color:#111827;}
.meta-optimization-option input:checked + span small{color:#475569;}
.meta-global-sync-note{margin:0 0 16px;padding:14px 16px;border:1px solid rgba(245,128,32,.24);border-radius:18px;background:linear-gradient(135deg,#fff7ed,#ffffff);display:grid;gap:5px;}
.meta-global-sync-note strong{color:#111827;font-size:14px;}
.meta-global-sync-note span{color:#475569;font-weight:700;line-height:1.4;}
.meta-global-sync-note a{color:#c05600;font-weight:900;text-decoration:none;}
.meta-global-field[readonly]{background:#f8fafc;border-color:rgba(15,23,42,.12);color:#111827;font-weight:800;}
.meta-global-source{display:block;margin-top:6px;color:#64748b;font-size:12px;font-weight:800;}
.meta-safe-check{color:#111827 !important;}
.meta-safe-check *{color:#111827;}


/* Phase 3.8.4 - Cleaner campaign summary layout */
.campaign-summary{
  grid-template-columns:minmax(88px,112px) minmax(0,1fr) minmax(160px,220px) auto!important;
  align-items:center!important;
  gap:14px!important;
}
.campaign-summary-kind{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:6px;
  min-width:0;
}
.campaign-summary .campaign-type-badge{
  width:auto!important;
  min-width:58px;
  max-width:100%;
  height:28px!important;
  padding:0 10px!important;
  border-radius:999px!important;
  font-size:10px!important;
  line-height:1!important;
  white-space:nowrap;
}
.campaign-summary .meta-mode-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto!important;
  max-width:100%;
  padding:4px 8px!important;
  margin-left:0!important;
  border-radius:999px;
  background:#fff7ed;
  border:1px solid rgba(245,128,32,.22);
  color:#9a4d00;
  font-weight:900;
  font-size:10px!important;
  line-height:1;
  letter-spacing:.02em;
  white-space:nowrap;
}
.campaign-summary .release-main{min-width:0;overflow:hidden;}
.campaign-summary .release-title,
.campaign-summary .release-artist{
  min-width:0;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.campaign-summary .campaign-summary-optimization{
  min-width:0!important;
  width:100%;
  max-width:220px;
  padding:8px 10px!important;
}
.campaign-summary .summary-opt-top{gap:6px;}
.campaign-summary .summary-opt-top strong{font-size:16px;}
.campaign-summary .summary-opt-top em{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
@media(max-width:980px){
  .campaign-summary{grid-template-columns:minmax(76px,96px) minmax(0,1fr) auto!important;}
  .campaign-summary .campaign-summary-optimization{grid-column:1/-1;max-width:none;}
}
@media(max-width:640px){
  .campaign-summary{grid-template-columns:1fr auto!important;gap:10px!important;}
  .campaign-summary-kind{grid-column:1/2;flex-direction:row;align-items:center;flex-wrap:wrap;}
  .campaign-summary .release-main{grid-column:1/-1;order:2;}
  .campaign-summary .campaign-summary-optimization{grid-column:1/-1;order:3;}
  .campaign-summary .campaign-chevron{grid-column:2/3;grid-row:1;justify-self:end;}
}


/* Phase 3.9.0 PWA / WebApp install icons */
.pwa-install-note{display:flex;gap:12px;align-items:center;padding:14px 16px;border:1px solid rgba(255,90,0,.18);background:linear-gradient(135deg,rgba(255,90,0,.09),rgba(255,184,0,.11));border-radius:18px;color:#1f1f1f;font-size:13px;line-height:1.35}
.pwa-install-note strong{color:#111}
