/* ============================================================
   style.css – TheTinFoil.com
   Single stylesheet for all pages.
   Mobile-first, dark mode, conspiracy/debunking theme.
   ============================================================ */

/* ---- DESIGN TOKENS ---- */
:root, [data-theme="light"] {
    /* Surfaces */
    --color-bg:       #f2f0eb;
    --color-surface:  #faf9f7;
    --color-border:   rgba(0,0,0,0.10);
    --color-divider:  rgba(0,0,0,0.07);

    /* Text */
    --color-text:       #1c1a14;
    --color-text-muted: #6b6965;

    /* Accent – silver/steel feels "tinfoil" */
    --color-primary:       #3d7a8a;
    --color-primary-hover: #2d5f6e;

    /* Status */
    --color-error:   #b53232;
    --color-success: #2e7d32;

    /* Spacing (4px base) */
    --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
    --space-5:1.25rem; --space-6:1.5rem; --space-8:2rem; --space-10:2.5rem;
    --space-12:3rem; --space-16:4rem;

    /* Type scale */
    --text-xs:  clamp(.75rem,  .7rem + .25vw, .875rem);
    --text-sm:  clamp(.875rem, .8rem + .35vw, 1rem);
    --text-base:clamp(1rem,    .95rem+ .25vw, 1.125rem);
    --text-lg:  clamp(1.125rem,1rem  + .75vw, 1.5rem);
    --text-xl:  clamp(1.5rem,  1.2rem+ 1.25vw,2.25rem);
    --text-2xl: clamp(2rem,    1.2rem+ 2.5vw, 3rem);

    /* Radii */
    --radius-sm:.375rem; --radius-md:.5rem; --radius-lg:.75rem; --radius-xl:1rem;

    /* Shadows */
    --shadow-sm:0 1px 3px rgba(0,0,0,.07);
    --shadow-md:0 4px 14px rgba(0,0,0,.09);

    /* Max widths */
    --content:960px; --narrow:600px;

    /* Transitions */
    --transition:160ms ease;

    /* Fonts */
    --font-body:   'Work Sans', system-ui, sans-serif;
    --font-display:'Montserrat', 'Work Sans', sans-serif;
}

/* ---- DARK MODE TOKENS ---- */
[data-theme="dark"] {
    --color-bg:       #131210;
    --color-surface:  #1c1b18;
    --color-border:   rgba(255,255,255,0.09);
    --color-divider:  rgba(255,255,255,0.05);
    --color-text:     #d8d5cf;
    --color-text-muted:#8a8884;
    --color-primary:       #5fa8b8;
    --color-primary-hover: #3d8ea0;
    --shadow-sm:0 1px 3px rgba(0,0,0,.3);
    --shadow-md:0 4px 14px rgba(0,0,0,.4);
}
@media (prefers-color-scheme:dark){
    :root:not([data-theme]){
        --color-bg:#131210; --color-surface:#1c1b18;
        --color-border:rgba(255,255,255,0.09);
        --color-divider:rgba(255,255,255,0.05);
        --color-text:#d8d5cf; --color-text-muted:#8a8884;
        --color-primary:#5fa8b8; --color-primary-hover:#3d8ea0;
        --shadow-sm:0 1px 3px rgba(0,0,0,.3);
        --shadow-md:0 4px 14px rgba(0,0,0,.4);
    }
}

/* ---- BASE RESET ---- */
*, *::before, *::after { box-sizing: border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:none; }
body {
    font-family:var(--font-body);
    font-size:var(--text-base);
    color:var(--color-text);
    background:var(--color-bg);
    min-height:100dvh;
    line-height:1.65;
}
img { display:block; max-width:100%; height:auto; }
a  { color:var(--color-primary); text-decoration:none; }
a:hover { text-decoration:underline; color:var(--color-primary-hover); }
input, textarea, select, button { font:inherit; color:inherit; }
h1,h2,h3,h4 { font-family:var(--font-display); line-height:1.2; text-wrap:balance; }
p, li { text-wrap:pretty; max-width:72ch; }
:focus-visible { outline:2px solid var(--color-primary); outline-offset:3px; border-radius:var(--radius-sm); }
@media (prefers-reduced-motion:reduce){ *, *::before, *::after { transition-duration:.01ms!important; animation-duration:.01ms!important; } }

/* ---- LAYOUT CONTAINERS ---- */
.container { max-width:var(--content); margin-inline:auto; padding-inline:var(--space-4); padding-block:var(--space-6); }
.narrow    { max-width:var(--narrow);  margin-inline:auto; padding-inline:var(--space-4); padding-block:var(--space-6); }

/* ---- HEADER ---- */
.site-header {
    background:var(--color-surface);
    border-bottom:1px solid var(--color-border);
    position:sticky; top:0; z-index:100;
    box-shadow:var(--shadow-sm);
}
.header-inner {
    max-width:var(--content);
    margin-inline:auto;
    padding:var(--space-3) var(--space-4);
    display:flex; align-items:center; justify-content:space-between; gap:var(--space-4);
}
.site-logo {
    display:flex; align-items:center; gap:var(--space-2);
    font-family:var(--font-display); font-weight:700;
    font-size:var(--text-lg); color:var(--color-text); text-decoration:none;
}
.site-logo:hover { color:var(--color-primary); }
.main-nav { display:flex; align-items:center; gap:var(--space-3); flex-wrap:wrap; }
.main-nav a { font-size:var(--text-sm); font-weight:500; color:var(--color-text-muted); }
.main-nav a:hover { color:var(--color-primary); text-decoration:none; }
/* Hamburger-less: let links wrap on small screens */

/* ---- FOOTER ---- */
.site-footer {
    text-align:center; padding:var(--space-8) var(--space-4);
    font-size:var(--text-sm); color:var(--color-text-muted);
    border-top:1px solid var(--color-divider); margin-top:var(--space-12);
}

/* ---- BUTTONS ---- */
.btn-primary, .btn-secondary {
    display:inline-flex; align-items:center; gap:var(--space-2);
    padding:var(--space-2) var(--space-5);
    border-radius:var(--radius-md); font-weight:600;
    font-size:var(--text-sm); transition:background var(--transition),color var(--transition);
    min-height:44px; /* touch target */
    cursor:pointer; border:none; text-decoration:none;
}
.btn-primary {
    background:var(--color-primary); color:#fff;
}
.btn-primary:hover { background:var(--color-primary-hover); text-decoration:none; color:#fff; }
.btn-secondary {
    background:transparent;
    border:1px solid var(--color-border);
    color:var(--color-text-muted);
}
.btn-secondary:hover { background:var(--color-divider); text-decoration:none; }
.btn-sm { padding:var(--space-1) var(--space-3); min-height:36px; font-size:var(--text-xs); }
.icon-btn { background:none; border:none; cursor:pointer; font-size:1.2rem; min-width:44px; min-height:44px; display:inline-flex; align-items:center; justify-content:center; border-radius:var(--radius-md); transition:background var(--transition); }
.icon-btn:hover { background:var(--color-divider); }

/* ---- FORMS ---- */
.form-card {
    background:var(--color-surface);
    border:1px solid var(--color-border);
    border-radius:var(--radius-xl);
    padding:var(--space-8);
    display:flex; flex-direction:column; gap:var(--space-5);
    box-shadow:var(--shadow-sm);
}
label {
    display:flex; flex-direction:column; gap:var(--space-1);
    font-size:var(--text-sm); font-weight:600; color:var(--color-text-muted);
}
input[type=text], input[type=email], input[type=password], input:not([type]), textarea, select {
    padding:var(--space-2) var(--space-3);
    border:1px solid var(--color-border);
    border-radius:var(--radius-md);
    background:var(--color-bg);
    color:var(--color-text);
    font-size:var(--text-base);
    width:100%;
    min-height:44px;
    transition:border-color var(--transition);
}
input:focus, textarea:focus { border-color:var(--color-primary); outline:none; }
textarea { resize:vertical; min-height:80px; }
.form-footer { font-size:var(--text-sm); text-align:center; color:var(--color-text-muted); }
details summary { cursor:pointer; font-size:var(--text-base); padding:var(--space-3) 0; }

/* ---- MESSAGES ---- */
.msg { padding:var(--space-3) var(--space-4); border-radius:var(--radius-md); margin-bottom:var(--space-4); font-size:var(--text-sm); }
.msg.error   { background:#fce8e8; color:var(--color-error); border:1px solid var(--color-error); }
.msg.success { background:#e8f5e9; color:var(--color-success); border:1px solid var(--color-success); }
[data-theme="dark"] .msg.error   { background:#3a1a1a; }
[data-theme="dark"] .msg.success { background:#1a2e1a; }

/* ---- SORT BAR ---- */
.sort-bar {
    display:flex; flex-wrap:wrap; gap:var(--space-3);
    margin-bottom:var(--space-6); align-items:center;
}
.sort-group { display:flex; gap:var(--space-2); flex-wrap:wrap; }
.sort-btn {
    padding:var(--space-1) var(--space-3);
    border-radius:var(--radius-full);
    border:1px solid var(--color-border);
    font-size:var(--text-xs); font-weight:600;
    color:var(--color-text-muted);
    background:var(--color-surface);
    text-decoration:none; min-height:36px; display:inline-flex; align-items:center;
    transition:background var(--transition), color var(--transition);
}
.sort-btn:hover, .sort-btn.active {
    background:var(--color-primary); color:#fff; border-color:var(--color-primary);
    text-decoration:none;
}

/* ---- FEATURED CARD (hero post) ---- */
.featured-card {
    background:var(--color-surface);
    border:1px solid var(--color-border);
    border-radius:var(--radius-xl);
    overflow:hidden;
    margin-bottom:var(--space-8);
    box-shadow:var(--shadow-md);
}
.featured-img {
    width:100%; height:clamp(180px,30vw,380px);
    background-size:cover; background-position:center;
    background-color:var(--color-divider);
}
.featured-body {
    padding:var(--space-6) var(--space-6);
    display:flex; flex-direction:column; gap:var(--space-3);
}
.featured-body h2 { font-size:var(--text-xl); }
.featured-body h2 a { color:var(--color-text); }
.featured-body h2 a:hover { color:var(--color-primary); text-decoration:none; }
.badge {
    display:inline-block; background:var(--color-primary); color:#fff;
    font-size:var(--text-xs); font-weight:700; letter-spacing:.05em;
    padding:2px 10px; border-radius:var(--radius-full); text-transform:uppercase;
}
.excerpt { color:var(--color-text-muted); }

/* ---- POST LIST (smaller entries) ---- */
.post-list { display:flex; flex-direction:column; gap:var(--space-3); }
.post-row {
    background:var(--color-surface);
    border:1px solid var(--color-border);
    border-radius:var(--radius-lg);
    padding:var(--space-4);
    display:flex; gap:var(--space-3); align-items:flex-start;
    box-shadow:var(--shadow-sm);
    transition:box-shadow var(--transition);
}
.post-row:hover { box-shadow:var(--shadow-md); }
.post-row .thumb img { width:80px; height:80px; object-fit:cover; border-radius:var(--radius-md); flex-shrink:0; }
.post-row-body h3 { font-size:var(--text-base); font-weight:700; }
.post-row-body h3 a { color:var(--color-text); }
.post-row-body h3 a:hover { color:var(--color-primary); text-decoration:none; }
.meta { font-size:var(--text-xs); color:var(--color-text-muted); }
.meta a { color:var(--color-text-muted); font-weight:600; }
.meta a:hover { color:var(--color-primary); }

/* ---- SUBMISSION VIEW ---- */
.sub-card {
    background:var(--color-surface);
    border:1px solid var(--color-border);
    border-radius:var(--radius-xl);
    padding:var(--space-8);
    margin-bottom:var(--space-8);
    box-shadow:var(--shadow-sm);
}
.sub-card h1 { font-size:var(--text-xl); margin-bottom:var(--space-3); }
.sub-body { margin-top:var(--space-5); }

/* Let Quill-rendered content look good */
.sub-body p   { margin-bottom:var(--space-3); max-width:none; }
.sub-body img { max-width:100%; border-radius:var(--radius-md); margin:var(--space-3) 0; }
.sub-body iframe, .sub-body video { max-width:100%; border-radius:var(--radius-md); }
.sub-body a   { color:var(--color-primary); }
.sub-body blockquote {
    border-left:3px solid var(--color-primary); padding-left:var(--space-4);
    color:var(--color-text-muted); margin:var(--space-4) 0;
}
.sub-body h1,.sub-body h2,.sub-body h3 { margin:var(--space-5) 0 var(--space-2); }

/* ---- VOTE ROW ---- */
.vote-row {
    display:flex; align-items:center; gap:var(--space-3);
    margin:var(--space-3) 0;
}
.vote-btn {
    background:var(--color-bg); border:1px solid var(--color-border);
    border-radius:var(--radius-full); padding:var(--space-1) var(--space-3);
    font-size:1rem; cursor:pointer; min-height:36px; min-width:44px;
    transition:background var(--transition);
}
.vote-btn:hover { background:var(--color-divider); }
.score { font-weight:700; font-size:var(--text-base); min-width:2ch; text-align:center; }

/* ---- COMMENTS ---- */
#comments { margin-top:var(--space-8); }
#comments h2 { font-size:var(--text-lg); margin-bottom:var(--space-4); }
.comment-form {
    display:flex; flex-direction:column; gap:var(--space-3);
    margin-bottom:var(--space-6);
}
.comment-tree { display:flex; flex-direction:column; gap:var(--space-3); }
.comment {
    background:var(--color-surface);
    border:1px solid var(--color-border);
    border-radius:var(--radius-lg);
    padding:var(--space-3) var(--space-4);
}
/* Indent child comments but cap to prevent overflow on mobile */
@media (max-width:480px) { .comment { margin-left:8px !important; } }
.reply-toggle {
    background:none; border:none; cursor:pointer;
    color:var(--color-primary); font-size:var(--text-xs); font-weight:600;
    padding:var(--space-1) var(--space-2); min-height:36px;
}
.reply-form { margin-top:var(--space-3); display:flex; flex-direction:column; gap:var(--space-2); }
.hidden { display:none !important; }

/* ---- PROFILE ---- */
.profile-header {
    background:var(--color-surface);
    border:1px solid var(--color-border);
    border-radius:var(--radius-xl);
    padding:var(--space-8);
    margin-bottom:var(--space-8);
    box-shadow:var(--shadow-sm);
    display:flex; flex-direction:column; gap:var(--space-3);
}
.social-links, .activity-links {
    display:flex; flex-wrap:wrap; gap:var(--space-3);
}
.social-links a {
    background:var(--color-bg); border:1px solid var(--color-border);
    border-radius:var(--radius-md); padding:var(--space-1) var(--space-3);
    font-size:var(--text-sm); font-weight:600; color:var(--color-text-muted);
    text-decoration:none; min-height:36px; display:inline-flex; align-items:center;
    transition:background var(--transition);
}
.social-links a:hover { background:var(--color-divider); color:var(--color-text); }

/* ---- REVISION TABLE ---- */
.rev-table { width:100%; border-collapse:collapse; margin-top:var(--space-6); font-size:var(--text-sm); }
.rev-table th { background:var(--color-divider); font-weight:700; text-align:left; padding:var(--space-2) var(--space-3); }
.rev-table td { padding:var(--space-2) var(--space-3); border-bottom:1px solid var(--color-divider); }
.rev-table tr.active-rev td { background:var(--color-primary); color:#fff; }
.rev-table tr.active-rev a { color:#fff; }

/* ---- EMPTY STATE ---- */
.empty-state {
    text-align:center; padding:var(--space-16) var(--space-4);
    color:var(--color-text-muted); font-size:var(--text-lg);
}

/* ---- QUILL DARK MODE OVERRIDE ---- */
[data-theme="dark"] .ql-toolbar.ql-snow,
[data-theme="dark"] .ql-container.ql-snow {
    border-color:var(--color-border);
    background:var(--color-bg);
    color:var(--color-text);
}
[data-theme="dark"] .ql-editor { color:var(--color-text); }
[data-theme="dark"] .ql-snow .ql-stroke { stroke:var(--color-text-muted); }
[data-theme="dark"] .ql-snow .ql-fill  { fill:var(--color-text-muted); }
[data-theme="dark"] .ql-snow .ql-picker-label { color:var(--color-text-muted); }

/* ---- MOBILE TWEAKS ---- */
@media (max-width:600px) {
    .header-inner { flex-wrap:wrap; }
    .main-nav { gap:var(--space-2); }
    .featured-body { padding:var(--space-4); }
    .sub-card { padding:var(--space-5) var(--space-4); }
    .form-card { padding:var(--space-5) var(--space-4); }
    h1 { font-size:var(--text-xl); }
}
