@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Manrope:wght@600;700;800&display=swap');

:root{--ink:#102d3d;--navy:#062c3d;--blue:#0877b9;--teal:#168b8b;--yellow:#f6c94b;--sand:#f4ead3;--cloud:#f4f7f8;--line:#dce5e8;--muted:#6f818a;--white:#fff;--danger:#ad343e;--success:#19734c;--shadow:0 16px 42px rgba(18,53,70,.08)}
*{box-sizing:border-box}html{font-family:"DM Sans",sans-serif;color:var(--ink);background:var(--cloud)}body{margin:0}h1,h2,h3,p{margin-top:0}h1,h2,h3,.kpi-card strong{font-family:"Manrope",sans-serif}a{color:inherit;text-decoration:none}button,input,select{font:inherit}.muted{color:var(--muted);line-height:1.6}.eyebrow{font-size:.71rem;letter-spacing:.17em;font-weight:800;color:var(--blue);margin-bottom:.55rem}.mark{width:64px;height:64px;border-radius:20px;background:var(--yellow);color:var(--navy);font:800 2.2rem/64px "Manrope";text-align:center;box-shadow:0 12px 30px rgba(246,201,75,.2)}.mark.small{width:40px;height:40px;border-radius:12px;font-size:1.45rem;line-height:40px;box-shadow:none}
.login-body{min-height:100vh;background:radial-gradient(circle at 20% 25%,#164e63 0,transparent 28%),linear-gradient(135deg,#031f2c,#073649 64%,#0b4354);display:grid;place-items:center;padding:30px}.login-shell{width:min(1100px,100%);display:grid;grid-template-columns:1.05fr .8fr;gap:72px;align-items:center}.login-shell.compact{grid-template-columns:minmax(0,620px);justify-content:center}.login-brand{color:white;padding:30px}.login-brand .eyebrow{color:#9fd3e7;margin-top:30px}.login-brand h1{font-size:clamp(2.6rem,5vw,4.7rem);line-height:1.02;letter-spacing:-.05em;margin-bottom:24px}.login-brand>p:last-child{color:#b9d0da;font-size:1.05rem;max-width:500px;line-height:1.7}.login-card{background:white;border-radius:28px;padding:44px;box-shadow:0 28px 90px rgba(0,0,0,.25)}.login-card h2{font-size:2rem;margin-bottom:8px}.login-card label{display:grid;gap:9px;font-weight:700;margin:28px 0 18px}.login-card input{width:100%;border:1px solid var(--line);border-radius:12px;padding:14px 16px;outline:0}.login-card input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(8,119,185,.1)}.security-note{text-align:center;color:#8999a0;font-size:.77rem;margin:20px 0 0}.code-note{background:#fff4f4;color:var(--danger);padding:14px;border-radius:10px;font-family:monospace;font-size:.8rem;margin:20px 0;overflow-wrap:anywhere}
.button{border:0;border-radius:10px;padding:11px 17px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:12px;transition:.2s}.button:hover{transform:translateY(-1px)}.button.primary{background:var(--navy);color:white;box-shadow:0 8px 20px rgba(6,44,61,.16)}.button.secondary{background:white;color:var(--ink);border:1px solid var(--line)}.button.wide{width:100%;padding:14px 18px}.alert{padding:13px 16px;border-radius:10px;margin-bottom:22px;font-weight:600}.alert.error{background:#fff0f1;color:var(--danger);border:1px solid #f2c7cb}.alert.success{background:#eaf8f1;color:var(--success);border:1px solid #bce4cf}
.app-body{min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;width:230px;background:var(--navy);padding:24px 18px;display:flex;flex-direction:column;color:white;z-index:5}.brand{display:flex;gap:12px;align-items:center;font:800 1.05rem "Manrope"}.brand span:last-child{display:grid}.brand b{font:500 .68rem "DM Sans";color:#9db5bf;margin-top:2px}.sidebar nav{display:grid;gap:6px;margin-top:50px}.sidebar nav a{padding:12px 13px;border-radius:9px;color:#b9ccd4;font-weight:600;display:flex;gap:12px;align-items:center}.sidebar nav a i{width:24px;font-style:normal;font-size:1.1rem;text-align:center}.sidebar nav a:hover,.sidebar nav a.active{background:#124458;color:white}.sidebar nav a.active{box-shadow:inset 3px 0 var(--yellow)}.sidebar-bottom{margin-top:auto;border-top:1px solid rgba(255,255,255,.12);padding-top:18px;display:flex;justify-content:space-between;align-items:end;font-size:.75rem;color:#b2c7cf}.sidebar-bottom span{display:grid}.sidebar-bottom small{color:#718f9b;margin-top:3px}.sidebar-bottom a{color:white;font-weight:700}.app-shell{margin-left:230px;min-height:100vh;display:flex;flex-direction:column}.content{width:min(1460px,100%);margin:0 auto;padding:38px 42px 56px;flex:1}.mobile-header{display:none}footer{padding:20px 42px 28px;color:#83939a;font-size:.75rem;display:flex;justify-content:space-between}
.hero-row{display:flex;justify-content:space-between;align-items:end;gap:30px;margin-bottom:18px}.hero-row h1{font-size:clamp(2rem,3vw,3rem);letter-spacing:-.045em;margin-bottom:10px}.hero-row .muted{margin-bottom:0}.date-filter{display:flex;align-items:end;gap:10px;background:white;border:1px solid var(--line);border-radius:13px;padding:10px;box-shadow:0 5px 16px rgba(18,53,70,.04)}.date-filter label{display:grid;gap:3px;font-size:.68rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}.date-filter input{border:0;color:var(--ink);font-weight:700;padding:3px;outline:0}.date-filter>span{padding-bottom:8px;color:#9badb4}.period-note{font-size:.8rem;color:var(--ink);font-weight:700;margin-bottom:24px}.period-note>span:last-child{color:var(--muted);font-weight:400;margin-left:9px}.live-dot{display:inline-block;width:8px;height:8px;border-radius:99px;background:#2eb872;margin-right:8px;box-shadow:0 0 0 4px rgba(46,184,114,.12)}
.kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:18px}.kpi-card{position:relative;overflow:hidden;background:white;border:1px solid var(--line);border-radius:15px;padding:18px;min-height:160px;box-shadow:0 5px 20px rgba(18,53,70,.035)}.kpi-card:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--accent)}.kpi-card.navy{--accent:var(--navy)}.kpi-card.blue{--accent:var(--blue)}.kpi-card.teal{--accent:var(--teal)}.kpi-card.yellow{--accent:var(--yellow)}.kpi-card.sand{--accent:#c59b56}.kpi-card>span{color:var(--muted);font-size:.8rem;font-weight:700}.kpi-card>strong{display:block;font-size:2.15rem;letter-spacing:-.05em;margin:14px 0 13px}.kpi-card>div{display:grid;gap:6px}.kpi-card b{font-size:.75rem;width:max-content;padding:3px 6px;border-radius:5px}.kpi-card b.up{color:var(--success);background:#e9f8f0}.kpi-card b.down{color:var(--danger);background:#fff0f1}.kpi-card b.neutral{color:var(--muted);background:var(--cloud)}.kpi-card small{color:#8b9aa1;font-size:.7rem;line-height:1.35}.classification-callout{background:#fff8df;border:1px solid #eed98d;border-radius:12px;padding:13px 16px;margin-bottom:18px;display:flex;justify-content:space-between;align-items:center;color:#644f10}.classification-callout span{display:grid;gap:2px}.classification-callout small{color:#8a7537}.classification-callout b{font-size:.85rem}
.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:18px}.dashboard-grid.demographics{grid-template-columns:1fr 1fr}.panel{background:white;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 6px 24px rgba(18,53,70,.045);margin-bottom:18px}.panel.span-2{min-width:0}.panel-head{display:flex;justify-content:space-between;align-items:start;gap:20px;margin-bottom:20px}.panel-head .eyebrow{margin-bottom:4px}.panel-head h2{font-size:1.15rem;margin:0}.panel-head small{display:block;color:var(--muted);margin-top:5px}.panel-head>a{color:var(--blue);font-size:.82rem;font-weight:700}.legend{display:flex;gap:16px;font-size:.7rem;color:var(--muted)}.legend span:before{content:"";display:inline-block;width:8px;height:8px;border-radius:99px;margin-right:6px}.legend .impressions:before{background:var(--blue)}.legend .clicks:before{background:var(--yellow)}.legend .social:before{background:var(--teal)}canvas{width:100%;display:block}.rank-list{display:grid;gap:15px}.rank-item{position:relative;display:grid;grid-template-columns:1fr auto;gap:10px;padding-bottom:11px}.rank-item div{display:grid;gap:3px}.rank-item strong{font-size:.82rem}.rank-item span{color:var(--muted);font-size:.7rem}.rank-item>b{font-size:.8rem}.rank-item i{position:absolute;height:3px;background:#e7edf0;bottom:0;left:0;right:0;border-radius:8px;overflow:hidden}.rank-item i:after{content:"";display:block;width:var(--w);height:100%;background:linear-gradient(90deg,var(--blue),var(--teal))}.post-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.post-card{border:1px solid var(--line);border-radius:12px;padding:16px;display:grid;grid-template-columns:auto 1fr auto;gap:12px;min-height:156px}.post-rank{width:26px;height:26px;border-radius:8px;background:var(--cloud);font-weight:800;font-size:.75rem;display:grid;place-items:center}.post-date{font-size:.67rem;color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.post-card h3{font-size:.87rem;line-height:1.45;margin-bottom:16px}.post-card>a{color:var(--blue);font-weight:800}.post-stats{display:flex;gap:16px;color:var(--muted);font-size:.66rem}.post-stats b{color:var(--ink);font-size:.78rem}.bar-list{display:grid;gap:13px}.bar-list>div{display:grid;grid-template-columns:minmax(140px,1.1fr) 2fr 45px;gap:12px;align-items:center;font-size:.75rem}.bar-list i{height:7px;border-radius:8px;background:#edf1f2;overflow:hidden}.bar-list i:after{content:"";display:block;height:100%;width:var(--w);background:var(--blue);border-radius:8px}.bar-list b{text-align:right}.empty{text-align:center;color:var(--muted);padding:28px!important}
.import-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}.upload-panel{padding:28px}.drop-zone{border:1.5px dashed #a9c0ca;border-radius:15px;min-height:235px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:7px;background:#f8fbfc;cursor:pointer;transition:.2s}.drop-zone:hover,.drop-zone.dragging{border-color:var(--blue);background:#eef8fc}.drop-zone input{display:none}.drop-zone strong{font:700 1rem "Manrope"}.drop-zone small{color:var(--muted)}.upload-icon{width:44px;height:44px;border-radius:13px;background:var(--navy);color:white;display:grid;place-items:center;font-size:1.4rem;margin-bottom:8px}.file-list{display:grid;gap:7px;margin:12px 0}.file-list div{background:var(--cloud);padding:9px 11px;border-radius:8px;font-size:.76rem;display:flex;justify-content:space-between}.rules-panel h2{font-size:1.35rem}.rule-list{padding:0;margin:24px 0 0;list-style:none;counter-reset:rules;display:grid;gap:17px}.rule-list li{counter-increment:rules;display:grid;grid-template-columns:32px 1fr;gap:2px 10px}.rule-list li:before{content:counter(rules);grid-row:1/3;width:28px;height:28px;border-radius:8px;background:#e8f4f9;color:var(--blue);display:grid;place-items:center;font-weight:800;font-size:.75rem}.rule-list b{font-size:.82rem}.rule-list span{color:var(--muted);font-size:.75rem;line-height:1.45}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;font-size:.78rem}th{color:var(--muted);font-size:.67rem;text-transform:uppercase;letter-spacing:.07em;text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}td{padding:13px 12px;border-bottom:1px solid #edf1f2;vertical-align:middle}tbody tr:last-child td{border-bottom:0}.filename{font-weight:700;max-width:280px}.pill{padding:4px 8px;border-radius:99px;background:#eaf5f9;color:#096d9d;font-size:.68rem;font-weight:700}
.legacy-import{display:flex;align-items:center;justify-content:space-between;gap:16px;border-top:1px solid var(--line);margin-top:18px;padding-top:18px}.legacy-import>span{display:grid;gap:3px}.legacy-import small{color:var(--muted);font-size:.72rem}
.mini-stats{display:flex;gap:12px}.mini-stats span{display:grid;background:white;border:1px solid var(--line);border-radius:12px;padding:12px 18px;color:var(--muted);font-size:.7rem}.mini-stats b{font:800 1.3rem "Manrope";color:var(--ink)}.taxonomy-note{background:var(--navy);color:white;border-radius:14px;padding:17px 20px;display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.taxonomy-note div{display:grid;gap:4px}.taxonomy-note span{color:#b7ccd5;font-size:.78rem}.text-button{background:none;border:0;color:var(--yellow);font-weight:700;cursor:pointer}.mapping-guide{grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:18px}.mapping-guide:not([hidden]){display:grid}.mapping-guide div{background:white;padding:14px;display:grid;gap:4px}.mapping-guide b{font-size:.78rem}.mapping-guide span{font-size:.7rem;color:var(--muted)}.posts-filter{display:flex;gap:9px;margin:18px 0}.posts-filter input,.posts-filter select,.posts-table select{border:1px solid var(--line);background:white;border-radius:9px;padding:10px 12px;color:var(--ink);outline:0}.posts-filter input{flex:1;max-width:420px}.posts-table{min-width:1050px}.posts-table th:first-child{width:38%}.post-cell{display:grid;gap:6px}.post-cell span{font-size:.65rem;color:var(--muted)}.post-cell a{font-weight:600;line-height:1.45}.post-cell a:hover{color:var(--blue)}.performance-cell{display:grid}.performance-cell b{font:800 1rem "Manrope"}.performance-cell span,.performance-cell small{color:var(--muted);font-size:.65rem}.performance-cell small{margin-top:5px;white-space:nowrap}.posts-table select{width:100%;min-width:150px;padding:9px;font-size:.74rem}.save-label{border:0;border-radius:8px;background:var(--navy);color:white;padding:8px 13px;font-weight:700;cursor:pointer}.save-label.saved{background:#e8f6ef;color:var(--success)}
@media(max-width:1180px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.post-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){.login-shell{grid-template-columns:1fr;gap:10px}.login-brand{display:none}.sidebar{transform:translateX(-100%);transition:.25s}.sidebar.open{transform:none}.app-shell{margin-left:0}.mobile-header{display:flex;padding:14px 20px;background:var(--navy);color:white;justify-content:space-between;align-items:center}.mobile-header button{background:none;border:0;color:white}.content{padding:26px 18px 44px}.hero-row{align-items:start;flex-direction:column}.date-filter{width:100%;flex-wrap:wrap}.kpi-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.dashboard-grid.demographics,.import-layout{grid-template-columns:1fr}.post-cards{grid-template-columns:1fr}.mapping-guide:not([hidden]){grid-template-columns:1fr 1fr}footer{padding:18px;display:grid;gap:4px}}
@media(max-width:520px){.login-body{padding:15px}.login-card{padding:30px 22px}.kpi-grid{grid-template-columns:1fr}.kpi-card{min-height:140px}.date-filter label{width:calc(50% - 20px)}.date-filter input{width:100%}.legend{display:none}.classification-callout{align-items:start;gap:12px}.mapping-guide:not([hidden]){grid-template-columns:1fr}.mini-stats{width:100%}.mini-stats span{flex:1}}
