/*
Theme Name: Mastodon Template
Theme URI: https://example.com
Author: no1san
Author URI: https://tigelaar.net
Description: Mastodon-achtige layout met vaste header, sticky linker sidebar (Left 1–3 widgets), infinite scroll en AJAX interacties, met licht/donker-modus.
Version: 0.7
Requires at least: 6.8.1
Tested up to: 6.8.3
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mastodon-template
Tags: blog, dark, light, two-columns, custom-colors, custom-menu, custom-logo, widgets
*/

/* Tokens (default dark) */
:root { --bg:#15202b; --card:#192734; --text:#ffffff; --text-dim:#8899a6; --accent:#1da1f2; --accent2:#794bc4; --border:#38444d; --radius:12px; --shadow:0 6px 20px rgba(0,0,0,.25); --header-h:60px; --column-gap:16px; }
:root[data-theme="light"] { --bg:#f5f7fb; --card:#ffffff; --text:#0f1720; --text-dim:#57606a; --accent:#1d7af2; --accent2:#7b5be1; --border:#e2e8f0; --shadow:0 6px 20px rgba(16,24,40,.08); }
@media (prefers-color-scheme: light) { :root:not([data-theme="dark"]):not([data-theme="light"]) { --bg:#f5f7fb; --card:#ffffff; --text:#0f1720; --text-dim:#57606a; --accent:#1d7af2; --accent2:#7b5be1; --border:#e2e8f0; --shadow:0 6px 20px rgba(16,24,40,.08); }}

*{box-sizing:border-box} html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";line-height:1.5}
a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block;border-radius:var(--radius)} button,input,textarea{font:inherit}

/* Header */
.mastodon-header{position:sticky;top:0;z-index:1000;height:var(--header-h);display:grid;grid-template-columns:1fr minmax(220px,600px) 1fr;align-items:center;gap:var(--column-gap);padding:0 16px;background:rgba(21,32,43,.9);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}
.masto-nav,.masto-user-actions{display:flex;align-items:center;gap:12px}
.masto-logo{font-weight:800;letter-spacing:.3px;color:var(--text)}
.masto-search{width:100%;display:flex;align-items:center;gap:8px}
.masto-search input[type="search"]{width:100%;padding:10px 12px;background:color-mix(in hsl,var(--bg) 70%, white 0%);color:var(--text);border:1px solid var(--border);border-radius:999px}
#theme-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:var(--card);color:var(--text);border:1px solid var(--border);cursor:pointer}
#theme-toggle .icon{font-size:16px}

/* Layout: two columns (left sticky + feed) */
.layout-wrapper{display:grid;grid-template-columns:275px minmax(0,600px);gap:var(--column-gap);justify-content:center;margin:0 auto;max-width:calc(275px + 600px + var(--column-gap));overflow:visible}
.left-sidebar{grid-column:1;position:sticky;top:calc(var(--header-h) + 16px);align-self:start;height:max-content;display:grid;gap:12px}
.main-feed{grid-column:2;display:grid;gap:10px;min-height:60vh;max-width:600px;width:100%}
.right-sidebar{display:none!important}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px}

/* Widgets in left sidebar */
.left-sidebar .widget + .widget{margin-top:12px}
.widget-title{font-weight:700;font-size:16px}

/* Compose & buttons */
.compose-card textarea{width:100%;min-height:80px;padding:12px;background:color-mix(in hsl,var(--bg) 70%, white 0%);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);resize:vertical}
.compose-actions{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.btn{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:color-mix(in hsl,var(--bg) 70%, white 0%);color:var(--text);cursor:pointer}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}

/* Post cards */
.post-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:15px;box-shadow:var(--shadow);margin:10px 0;display:grid;grid-template-columns:48px 1fr;gap:12px}
.post-head{display:flex;align-items:baseline;gap:6px}
.post-head .name{font-weight:700}
.post-head .handle,.post-head .time{color:var(--text-dim);font-size:14px}
.post-content{margin-top:4px}
.post-media-grid{margin-top:8px;display:grid;gap:6px}
.post-media-grid.cols-1{grid-template-columns:1fr}
.post-media-grid.cols-2{grid-template-columns:1fr 1fr}
.post-media-grid.cols-3{grid-template-columns:1fr 1fr 1fr}
.post-media-grid.cols-4{grid-template-columns:1fr 1fr}
.post-media-grid img{border-radius:var(--radius);transition:transform .2s ease}
.post-media-grid img:hover{transform:scale(1.01)}

.interaction-buttons{margin-top:8px;display:flex;align-items:center;gap:18px;color:var(--text-dim);font-size:14px}
.interaction-buttons .btn-icon{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.interaction-buttons .btn-icon[data-active="true"]{color:var(--accent)}

/* Footer */
.mastodon-footer{max-width:1200px;margin:24px auto;padding:0 16px;color:var(--text-dim)}

/* Responsive */
@media (max-width: 900px){
  .layout-wrapper{grid-template-columns:minmax(0,1fr);max-width:700px}
  .left-sidebar{display:none}
}
