/*
Theme Name: FDEBlog
Theme URI: https://fde.blog/
Author: FDE
Description: A clean two-column WordPress blog theme based on PhoenixBlue’s simple layout, restyled to match the FDE landing page/app visual system.
Version: 1.0.3
Requires at least: 5.8
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: fdeblog
*/
:root{--bg:#070a0f;--panel:rgba(19,24,32,.74);--panel-2:rgba(23,29,39,.62);--text:#eef5fb;--muted:#9eafbf;--quiet:#728395;--brand:#68e3ef;--brand-2:#9af6ff;--accent:#a8f56d;--blue:#31b9ff;--danger:#ff6b6b;--ok:#5af08d;--line:rgba(255,255,255,.105);--line-strong:rgba(255,255,255,.17);--ring:rgba(104,227,239,.45);--shadow:0 28px 80px rgba(0,0,0,.42);--shadow-soft:0 12px 36px rgba(0,0,0,.26);--radius:24px;--gap:clamp(22px,4vw,54px);color-scheme:dark}*{box-sizing:border-box}html{min-height:100%;background:var(--bg)}body{min-height:100%;margin:0;color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.55;background:radial-gradient(900px 520px at 16% 14%,rgba(168,245,109,.12),transparent 62%),radial-gradient(760px 560px at 86% 2%,rgba(49,185,255,.15),transparent 62%),radial-gradient(900px 700px at 80% 92%,rgba(104,227,239,.09),transparent 58%),linear-gradient(180deg,#080b11 0%,#06080d 100%);overflow-x:hidden}body::before{content:"";position:fixed;inset:0;pointer-events:none;background:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.014) 1px,transparent 1px);background-size:42px 42px;mask-image:radial-gradient(circle at 50% 20%,black,transparent 72%);opacity:.42}a{color:var(--brand-2);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}::selection{background:rgba(104,227,239,.35)}.site-shell{position:relative;width:min(1180px,100%);margin:0 auto;padding:30px clamp(18px,3vw,34px) 76px}.site-header{display:flex;align-items:center;justify-content:space-between;gap:22px;margin-bottom:clamp(34px,6vw,70px)}.brand{display:flex;align-items:center;gap:12px;color:var(--text);font-weight:900;letter-spacing:-.02em;text-decoration:none;white-space:nowrap;font-size:18px}.brand:hover{text-decoration:none}.logo-badge,.custom-logo{width:42px;height:42px;border-radius:12px;display:block;object-fit:contain;filter:drop-shadow(0 10px 26px rgba(104,227,239,.20))}.primary-nav .menu{display:flex;align-items:center;justify-content:flex-end;gap:8px;list-style:none;margin:0;padding:0;flex-wrap:wrap}.primary-nav a{display:inline-flex;min-height:40px;align-items:center;padding:9px 13px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.035);color:var(--text);font-size:13px;font-weight:800}.primary-nav a:hover,.primary-nav .current-menu-item>a,.primary-nav .current_page_item>a{background:rgba(104,227,239,.095);border-color:rgba(104,227,239,.22);color:var(--brand-2);text-decoration:none}.site-main{display:block}.hero{margin-bottom:24px}.hero h1{max-width:13ch;margin:0;font-size:clamp(44px,7vw,78px);line-height:1.03;letter-spacing:-.055em;text-wrap:balance}.sub{margin:18px 0 0;max-width:58ch;color:var(--muted);font-size:clamp(18px,2.2vw,25px);line-height:1.35;text-wrap:balance}.content-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,300px);gap:var(--gap);align-items:start;width:100%;max-width:100%;overflow:visible}.posts-list{display:grid;gap:20px}.sidebar{display:grid;gap:16px;position:sticky;top:22px;min-width:0;max-width:100%}.card{position:relative;min-width:0;padding:clamp(20px,2.4vw,30px);border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.03)),var(--panel);box-shadow:var(--shadow-soft);backdrop-filter:blur(18px)}.featured{box-shadow:var(--shadow),0 0 0 1px rgba(104,227,239,.035)}.featured::before,.accent-card::before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--brand),var(--blue)) top center/calc(100% - 4px) 4px no-repeat;opacity:.9;pointer-events:none}.eyebrow{display:inline-flex;align-items:center;gap:8px;margin:0 0 14px;padding:7px 10px;border:1px solid rgba(104,227,239,.18);border-radius:999px;background:rgba(104,227,239,.065);color:var(--brand-2);font-size:12px;font-weight:850;letter-spacing:.08em;text-transform:uppercase}.eyebrow::before{content:"";width:7px;height:7px;border-radius:999px;background:var(--accent);box-shadow:0 0 18px rgba(168,245,109,.75)}.post-title{margin:0 0 10px;font-size:clamp(28px,4.2vw,46px);line-height:1.08;letter-spacing:-.045em;text-wrap:balance}.post-title a{color:var(--text)}.post-title a:hover{color:var(--brand-2);text-decoration:none}.post-meta{color:var(--quiet);font-size:13px;margin-bottom:20px}.post-entry{color:color-mix(in oklab,var(--text) 90%,var(--muted));font-size:16px}.post-entry p:first-child{margin-top:0}.post-entry p:last-child{margin-bottom:0}.post-entry h2,.post-entry h3,.post-entry h4{color:var(--text);letter-spacing:-.025em;line-height:1.15}.post-entry blockquote{margin:24px 0;padding:16px 20px;border-left:4px solid var(--brand);background:rgba(255,255,255,.04);border-radius:0 18px 18px 0;color:var(--muted)}.post-entry code{padding:.15em .35em;border-radius:8px;background:rgba(255,255,255,.08);color:var(--brand-2)}.post-entry pre{overflow:auto;padding:18px;border-radius:18px;background:#05080d;border:1px solid var(--line)}.post-thumb{display:block;margin:-8px -8px 20px;overflow:hidden;border-radius:18px;border:1px solid var(--line)}.post-thumb img{display:block;width:100%}.post-actions{display:flex;gap:10px;flex-wrap:wrap;margin:24px 0 0}.btn,button,input[type=submit]{appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:12px 18px;border:1px solid transparent;border-radius:999px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#011117;font-size:14px;font-weight:850;letter-spacing:-.01em;cursor:pointer;box-shadow:0 14px 34px rgba(104,227,239,.22);transition:transform .12s ease,filter .18s ease;text-decoration:none}.btn:hover,button:hover,input[type=submit]:hover{transform:translateY(-1px);filter:brightness(1.04);text-decoration:none}.btn.alt{color:var(--text);background:rgba(255,255,255,.04);border-color:var(--line);box-shadow:none}.widget h2,.widget-title{margin:0 0 14px;font-size:18px;letter-spacing:-.02em}.widget ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}.widget li{color:var(--muted);font-size:14px}.widget li a{display:inline-flex;padding:2px 0}.search-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end;max-width:100%}.search-form input[type=search],input[type=text],input[type=email],input[type=url],textarea{min-width:0;width:100%;color:var(--text);background:rgba(255,255,255,.055);border:1px solid var(--line-strong);border-radius:14px;padding:13px 14px;font:inherit;line-height:1.35}.search-form input[type=search]:focus,input:focus,textarea:focus{outline:none;border-color:transparent;box-shadow:0 0 0 4px var(--ring);background:rgba(255,255,255,.08)}textarea{min-height:130px;resize:vertical}.screen-reader-text{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}.footnav{display:flex;justify-content:space-between;gap:12px;margin:8px 0 0}.site-footer{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:70px;padding-top:20px;border-top:1px solid rgba(255,255,255,.09);color:var(--quiet);font-size:13px}.comments-area{margin-top:20px}.comment-list{margin:0 0 24px;padding-left:22px}.comment-list li{margin:14px 0}.comment-body{padding:16px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.035)}.comment-meta{font-size:13px;color:var(--quiet)}.comment-content{color:var(--muted)}.page-links{margin-top:20px;color:var(--muted)}.alignright{float:right}.alignleft{float:left}.aligncenter{display:block;margin-left:auto;margin-right:auto}.wp-caption{max-width:100%}.wp-caption-text,.gallery-caption{color:var(--quiet);font-size:13px}.sticky{box-shadow:var(--shadow),0 0 0 1px rgba(168,245,109,.18)}.bypostauthor .comment-body{border-color:rgba(104,227,239,.32)}@media(max-width:980px){.content-grid{grid-template-columns:1fr}.sidebar{position:relative;top:auto;grid-template-columns:repeat(2,minmax(0,1fr))}.hero h1{max-width:12ch}}@media(max-width:680px){.site-shell{padding-top:22px}.site-header{align-items:stretch;flex-direction:column}.primary-nav .menu{justify-content:flex-start}.sidebar{grid-template-columns:1fr}.search-form{grid-template-columns:1fr}.search-form button,.btn{width:100%}.hero h1{font-size:clamp(40px,15vw,62px);max-width:10.5ch;line-height:1.04}.site-footer{flex-direction:column}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}


/* v1.0.1: Homepage hero participates in the same two-column grid as posts + sidebar, then spans both columns. */
.content-grid-home{grid-template-rows:auto auto;}
.content-grid-home>.hero{grid-column:1 / -1;width:100%;max-width:none;margin-bottom:0;}
.content-grid-home>.posts-list{grid-column:1;}
.content-grid-home>.sidebar{grid-column:2;}
@media(max-width:980px){.content-grid-home>.hero,.content-grid-home>.posts-list,.content-grid-home>.sidebar{grid-column:1;}}

/* v1.0.2: prevent the right sidebar/search form from forcing horizontal overflow on medium viewports. */
.site-shell{max-width:100%;overflow-x:hidden;}
.posts-list,.sidebar,.widget,.search-form,.search-form label{min-width:0;}
.sidebar .widget{overflow:hidden;}
.search-form input[type=search]{min-width:0;width:100%;}
@media(max-width:1120px){
  .content-grid{grid-template-columns:minmax(0,1fr) minmax(250px,290px);gap:clamp(18px,3vw,34px);}
  .site-shell{padding-left:clamp(18px,2.5vw,26px);padding-right:clamp(18px,2.5vw,26px);}
}
@media(max-width:860px){
  .content-grid{grid-template-columns:1fr;}
  .sidebar{position:relative;top:auto;grid-template-columns:1fr;}
}


/* v1.0.3: harden medium-width layout.
   At laptop/tablet widths the old two-column grid could still fit mathematically,
   but the sidebar widgets/search controls could create an effective wider column.
   Stack earlier, and make every grid item explicitly shrinkable. */
.site-shell{
  width:min(1180px, calc(100vw - 0px));
  max-width:100vw;
}
.site-main,.content-grid,.content-grid-home,.posts-list,.sidebar,.card,.widget{
  min-width:0;
  max-width:100%;
}
.content-grid{
  grid-template-columns:minmax(0, 1fr) minmax(240px, 300px);
}
.sidebar{
  width:100%;
}
.sidebar .card,.sidebar .widget{
  width:100%;
}
.search-form{
  grid-template-columns:minmax(0,1fr) auto;
}
.search-form input[type=search],
.search-form button{
  max-width:100%;
}
@media(max-width:1100px){
  .content-grid,
  .content-grid-home{
    grid-template-columns:1fr;
  }
  .content-grid-home>.hero,
  .content-grid-home>.posts-list,
  .content-grid-home>.sidebar,
  .posts-list,
  .sidebar{
    grid-column:1 / -1;
  }
  .sidebar{
    position:relative;
    top:auto;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .search-form{
    grid-template-columns:minmax(0,1fr) auto;
  }
}
@media(max-width:720px){
  .site-shell{
    padding-left:18px;
    padding-right:18px;
  }
  .sidebar{
    grid-template-columns:1fr;
  }
  .search-form{
    grid-template-columns:1fr;
  }
  .search-form button{
    width:100%;
  }
}
