/*
Theme Name: Grabner IT Security Services
Theme URI: https://www.linkedin.com/in/georggrabner
Author: Georg Grabner
Author URI: https://www.linkedin.com/in/georggrabner
Description: Single-page landing theme for Grabner IT Security Services — an independent Identity & Access Management consultancy. Light, clean design in the brand cyan/navy palette with sections for About, Services, Experience, Credentials and Contact.
Version: 1.0.0
Requires at least: 5.9
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: grabner-iam
*/

:root{
  --navy:#1b1c4b;
  --navy-2:#262a6e;
  --ink:#1f2440;
  --cyan:#19c6d6;
  --cyan-deep:#1aa3e0;
  --teal:#2bd4c4;
  --bg:#ffffff;
  --bg-soft:#f5f8fc;
  --line:#e3e9f2;
  --muted:#5d6885;
  --grad:linear-gradient(135deg,#2bd4c4 0%,#19c6d6 45%,#1aa3e0 100%);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Segoe UI',-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.gw-section{padding:96px 0}
h2{font-size:2rem;color:var(--navy);letter-spacing:-.5px;margin-bottom:14px}
.eyebrow{text-transform:uppercase;letter-spacing:2.5px;font-size:.78rem;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:10px;display:block}
.lead{color:var(--muted);font-size:1.06rem;max-width:680px}

/* NAV */
.gw-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.gw-nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--navy);letter-spacing:.5px}
.brand .mark{width:40px;height:40px;flex:none}
.brand small{display:block;font-size:.6rem;font-weight:600;letter-spacing:2px;color:var(--cyan-deep)}
.navlinks{display:flex;gap:30px;font-size:.92rem;font-weight:600;color:var(--ink)}
.navlinks a{color:var(--muted);transition:color .2s}
.navlinks a:hover{color:var(--navy)}
.btn{display:inline-block;background:var(--grad);color:#fff;font-weight:700;
  padding:12px 24px;border-radius:8px;font-size:.92rem;border:none;cursor:pointer;
  box-shadow:0 6px 18px rgba(25,198,214,.3);transition:transform .15s,box-shadow .2s}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(25,198,214,.42)}
.btn-ghost{background:transparent;color:var(--navy);border:1.5px solid var(--line);box-shadow:none}
.btn-ghost:hover{border-color:var(--cyan);transform:translateY(-2px);box-shadow:none}
.menu-btn{display:none;background:none;border:none;font-size:1.6rem;color:var(--navy);cursor:pointer}

/* HERO */
.hero{padding:110px 0 90px;background:
  radial-gradient(1100px 500px at 80% -10%,rgba(25,198,214,.10),transparent 60%),
  var(--bg-soft)}
.hero-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:54px;align-items:center}
.hero h1{font-size:3rem;line-height:1.1;color:var(--navy);letter-spacing:-1px;margin-bottom:18px}
.hero h1 .hl{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:1.12rem;color:var(--muted);max-width:540px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:28px;margin-top:38px;flex-wrap:wrap}
.hero-badges .b{font-size:.82rem;color:var(--muted)}
.hero-badges .b strong{display:block;font-size:1.7rem;color:var(--navy);font-weight:800;line-height:1}
.shield-card{display:flex;align-items:center;justify-content:center}
.shield-card .disc{position:relative;width:230px;height:230px;border-radius:50%;background:#fff;
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  box-shadow:0 22px 50px rgba(27,28,75,.12)}
.shield-card .disc::after{content:"";position:absolute;width:230px;height:230px;border-radius:50%;
  box-shadow:inset 0 0 0 8px rgba(25,198,214,.08)}
.shield-card svg{width:150px;height:150px}

/* CLIENTS STRIP */
.strip{background:var(--navy);color:#cfd6f5}
.strip .wrap{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;align-items:center;
  padding:22px 24px;font-size:.85rem;letter-spacing:.5px}
.strip span{opacity:.55;text-transform:uppercase;font-weight:600}
.strip b{color:#fff;font-weight:700}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.about p{margin-bottom:16px;color:var(--muted)}
.pill-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.pill{background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;
  padding:7px 16px;font-size:.85rem;font-weight:600;color:var(--navy)}
.sub-h{color:var(--navy);font-size:1.05rem;margin-bottom:14px}
.sub-h.mt{margin:24px 0 14px}

/* SERVICES */
.services{background:var(--bg-soft)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 26px;
  transition:transform .18s,box-shadow .25s,border-color .2s}
.card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(27,28,75,.10);border-color:transparent}
.card .ic{width:48px;height:48px;border-radius:11px;background:var(--grad);display:flex;
  align-items:center;justify-content:center;margin-bottom:18px}
.card .ic svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2}
.card h3{color:var(--navy);font-size:1.12rem;margin-bottom:8px}
.card p{color:var(--muted);font-size:.93rem}

/* EXPERIENCE */
.timeline{margin-top:46px;border-left:2px solid var(--line);padding-left:30px;display:flex;flex-direction:column;gap:34px}
.tl{position:relative}
.tl::before{content:"";position:absolute;left:-39px;top:4px;width:14px;height:14px;border-radius:50%;
  background:var(--grad);box-shadow:0 0 0 4px #fff}
.tl .yr{font-size:.8rem;font-weight:700;color:var(--cyan-deep);letter-spacing:1px;text-transform:uppercase}
.tl h3{color:var(--navy);font-size:1.12rem;margin:3px 0}
.tl .co{font-weight:600;color:var(--ink);font-size:.92rem}
.tl p{color:var(--muted);font-size:.93rem;margin-top:6px}
.note{margin-top:30px;color:var(--muted);font-size:.92rem}
.note strong{color:var(--navy)}

/* CREDENTIALS */
.cred-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;margin-top:42px}
.cred-h{color:var(--navy);font-size:1.05rem;margin-bottom:16px}
.cred-h.mt{margin-top:28px}
.cred-list{list-style:none}
.cred-list li{padding:13px 0;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--ink)}
.cred-list li b{font-weight:700}
.cred-list li span{display:block;color:var(--muted);font-size:.82rem;margin-top:2px}

/* CONTACT */
.contact{background:var(--navy);color:#eef1ff}
.contact h2{color:#fff}
.contact .lead{color:#b9c0e6}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;margin-top:38px;align-items:start}
.contact-info p{color:#c6cdee;margin-bottom:18px;font-size:.96rem}
.contact-info a{color:var(--teal);font-weight:600}
.ci-row{display:flex;gap:12px;align-items:center;margin-bottom:16px;font-size:.95rem;color:#dfe4ff}
.ci-row svg{width:20px;height:20px;stroke:var(--cyan);fill:none;stroke-width:2;flex:none}
.gw-form{display:grid;gap:14px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.gw-form label{font-size:.8rem;font-weight:600;color:#c6cdee;display:block;margin-bottom:6px}
.gw-form input,.gw-form textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);
  border-radius:8px;padding:12px 14px;color:#fff;font-family:inherit;font-size:.95rem;transition:border-color .2s,background .2s}
.gw-form input:focus,.gw-form textarea:focus{outline:none;border-color:var(--cyan);background:rgba(255,255,255,.1)}
.gw-form textarea{min-height:120px;resize:vertical}
.gw-form .btn{justify-self:start;margin-top:4px}
.form-note{font-size:.78rem;color:#8e97c4;margin-top:4px}

/* FOOTER */
.gw-footer{background:#14153a;color:#9aa2cf;font-size:.85rem}
.gw-footer .wrap{display:flex;justify-content:space-between;align-items:center;padding:26px 24px;flex-wrap:wrap;gap:12px}
.gw-footer a:hover{color:#fff}

@media(max-width:860px){
  .gw-section{padding:70px 0}
  .hero-grid,.about-grid,.contact-grid,.cred-grid{grid-template-columns:1fr;gap:34px}
  .shield-card{order:-1}
  .shield-card .disc{width:170px;height:170px}
  .shield-card .disc::after{width:170px;height:170px}
  .shield-card svg{width:108px;height:108px}
  .hero h1{font-size:2.3rem}
  .cards{grid-template-columns:1fr}
  .navlinks{display:none}
  .menu-btn{display:block}
  .navlinks.open{display:flex;position:absolute;top:72px;left:0;right:0;background:#fff;
    flex-direction:column;padding:18px 24px;border-bottom:1px solid var(--line);gap:16px}
  .frow{grid-template-columns:1fr}
}
