/*
Theme Name: 150Sites
Theme URI: https://150sites.com
Author: 150Sites
Author URI: https://150sites.com
Description: Custom brochure-site theme for 150Sites — web design, development, and hosting for small business. Replaces the previous Be theme build with a lightweight, hand-coded theme (no page builder dependency).
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: Proprietary
Text Domain: onefifty
*/

  :root{
    --bg:#FAFAF8;
    --surface:#FFFFFF;
    --ink:#14151A;
    --ink-soft:#63636D;
    --ink-faint:#9A98A3;
    --brand:#1E7A52;
    --brand-dark:#155F40;
    --brand-light:#E7F5EC;
    --coral:#FF6A4D;
    --coral-dark:#E8562F;
    --coral-light:#FFE9E1;
    --border:rgba(20,21,26,0.08);
    --shadow-sm:0 1px 2px rgba(20,21,26,0.04), 0 1px 1px rgba(20,21,26,0.03);
    --shadow-md:0 8px 24px rgba(20,21,26,0.06), 0 2px 6px rgba(20,21,26,0.04);
    --shadow-lg:0 24px 60px rgba(20,21,26,0.10), 0 8px 20px rgba(20,21,26,0.05);
    --r-sm:12px;
    --r-md:20px;
    --r-lg:28px;
    --r-pill:999px;
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:var(--bg);
    color:var(--ink);
    font-family:'Inter',sans-serif;
    font-size:16px;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,h4{
    font-family:'Bricolage Grotesque',sans-serif;
    margin:0;
    letter-spacing:-0.02em;
  }
  a{color:inherit;text-decoration:none;}
  .mono{font-family:'IBM Plex Mono',monospace;}
  .wrap{max-width:1180px;margin:0 auto;padding:0 28px;}
  img{max-width:100%;display:block;}

  .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s ease;}
  .reveal.in{opacity:1;transform:translateY(0);}

  .eyebrow{
    font-family:'IBM Plex Mono',monospace;
    font-size:12.5px;
    letter-spacing:0.08em;
    text-transform:uppercase;
    display:inline-flex;
    align-items:center;
    gap:8px;
    margin-bottom:16px;
    color:var(--brand);
    background:var(--brand-light);
    padding:6px 14px;
    border-radius:var(--r-pill);
    font-weight:500;
  }
  .eyebrow.coral{color:var(--coral-dark);background:var(--coral-light);}
  .eyebrow.on-dark{color:#CFF3DE;background:rgba(255,255,255,0.08);}

  /* ---------- Header ---------- */
  header{
    position:sticky;top:0;z-index:50;
    background:rgba(250,250,248,0.85);
    backdrop-filter:blur(10px);
    border-bottom:1px solid var(--border);
  }
  .nav-inner{
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 28px;max-width:1180px;margin:0 auto;
  }
  .logo{
    font-family:'Bricolage Grotesque',sans-serif;
    font-weight:700;font-size:29px;color:var(--ink);
    display:flex;align-items:center;gap:8px;
  }
  .logo span{color:var(--brand);}
  .links{display:flex;gap:34px;align-items:center;}
  .links a{
    color:var(--ink-soft);
    font-size:14.5px;font-weight:500;
    transition:color .15s;
  }
  .links a:hover{color:var(--ink);}
  .call-btn{
    font-family:'Inter',sans-serif;
    font-size:14px;
    color:#fff;
    background:var(--ink);
    padding:11px 22px;
    border-radius:var(--r-pill);
    font-weight:600;
    white-space:nowrap;
    transition:background .15s, transform .15s;
  }
  .call-btn:hover{background:var(--brand-dark);transform:translateY(-1px);}
  .hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;}
  .hamburger span{display:block;width:22px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px;}
  .mobile-panel{display:none;flex-direction:column;background:var(--surface);border-top:1px solid var(--border);}
  .mobile-panel a{padding:16px 28px;color:var(--ink);font-size:15px;border-bottom:1px solid var(--border);}
  .mobile-panel.open{display:flex;}

  /* ---------- Hero ---------- */
  .hero{padding:88px 0 60px;position:relative;overflow:hidden;}
  .hero-bg{
    position:absolute;inset:0;z-index:0;
    background:
      radial-gradient(560px 420px at 82% 8%, rgba(30,122,82,0.14), transparent 60%),
      radial-gradient(480px 380px at 8% 30%, rgba(255,106,77,0.10), transparent 60%);
  }
  .hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center;}
  .hero h1{
    font-size:58px;
    font-weight:700;
    line-height:1.04;
    color:var(--ink);
  }
  .hero h1 .accent{color:var(--brand);}
  .hero p.sub{
    margin-top:22px;
    font-size:18.5px;
    color:var(--ink-soft);
    max-width:480px;
    line-height:1.6;
  }
  .cta-row{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}
  .btn-primary{
    background:var(--ink);
    color:#fff;
    font-weight:600;
    padding:15px 28px;
    border-radius:var(--r-pill);
    font-size:15px;
    display:inline-block;
    transition:background .18s, transform .18s;
    border:none;cursor:pointer;
  }
  .btn-primary:hover{background:var(--brand-dark);transform:translateY(-1px);}
  .btn-primary.coral{background:var(--coral);}
  .btn-primary.coral:hover{background:var(--coral-dark);}
  .btn-ghost{
    border:1.5px solid var(--border);
    color:var(--ink);
    padding:13.5px 27px;
    border-radius:var(--r-pill);
    font-size:15px;
    font-weight:600;
    transition:border-color .15s, background .15s;
  }
  .btn-ghost:hover{border-color:var(--ink);background:var(--surface);}

  .stack{position:relative;height:420px;}
  .stack-card{
    position:absolute;
    width:100%;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--r-lg);
    box-shadow:var(--shadow-lg);
    padding:26px;
  }
  .stack-card.c1{top:60px;left:26px;right:-10px;transform:rotate(-3deg);z-index:1;opacity:0.85;}
  .stack-card.c2{top:30px;left:6px;right:6px;transform:rotate(2deg);z-index:2;opacity:0.95;}
  .stack-card.c3{top:0;left:-10px;right:26px;transform:rotate(-1deg);z-index:3;}
  .stack-card .dot-row{display:flex;gap:6px;margin-bottom:18px;}
  .stack-card .dot{width:9px;height:9px;border-radius:50%;background:var(--border);}
  .stack-card .bar{height:9px;border-radius:5px;background:var(--border);margin-bottom:10px;}
  .stack-card .bar.w60{width:60%;}
  .stack-card .bar.w80{width:80%;}
  .stack-card .bar.w40{width:40%;}
  .stack-card .price-tag{
    display:inline-flex;align-items:center;gap:6px;
    background:var(--brand-light);color:var(--brand-dark);
    font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:500;
    padding:7px 14px;border-radius:var(--r-pill);margin-top:8px;
  }

  /* ---------- Section basics ---------- */
  section{padding:96px 0;}
  .section-head{max-width:640px;margin-bottom:56px;}
  .section-head h2{font-size:39px;font-weight:700;line-height:1.14;}
  .section-head p{margin-top:14px;color:var(--ink-soft);font-size:16.5px;}
  .center{text-align:center;margin-left:auto;margin-right:auto;}

  /* ---------- Services ---------- */
  .services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
  .service-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--r-md);
    padding:32px 28px;
    transition:box-shadow .2s, transform .2s;
  }
  .service-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);}
  .icon-badge{
    width:44px;height:44px;border-radius:14px;
    display:flex;align-items:center;justify-content:center;
    background:var(--brand-light);color:var(--brand-dark);
    font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:16px;
    margin-bottom:20px;
  }
  .service-card:nth-child(2) .icon-badge{background:var(--coral-light);color:var(--coral-dark);}
  .service-card:nth-child(3) .icon-badge{background:#EAE9FB;color:#5A4FCF;}
  .service-card h3{font-size:21px;margin-bottom:6px;}
  .service-card .price{
    font-family:'IBM Plex Mono',monospace;
    color:var(--ink-soft);font-size:13.5px;font-weight:500;
    margin-bottom:14px;
  }
  .service-card p{color:var(--ink-soft);font-size:15px;margin-bottom:22px;}
  .service-card .link{
    font-size:14px;font-weight:600;color:var(--ink);
    display:inline-flex;align-items:center;gap:6px;
  }
  .service-card .link:after{content:"→";transition:transform .15s;}
  .service-card:hover .link:after{transform:translateX(3px);}

  /* ---------- Packages ---------- */
  .packages-card{background:var(--ink);color:#fff;border-radius:40px;padding:96px 40px;}
  .packages-card .section-head h2{color:#fff;}
  .packages-card .section-head p{color:rgba(255,255,255,0.62);}
  .promo-banner{
    display:flex;align-items:center;gap:14px;
    background:rgba(255,106,77,0.14);
    border:1px solid rgba(255,106,77,0.3);
    border-radius:var(--r-md);
    padding:16px 22px;
    font-size:14px;
    color:#fff;
    margin-bottom:48px;
  }
  .promo-banner .code{
    font-family:'IBM Plex Mono',monospace;
    background:var(--coral);color:#fff;
    padding:3px 10px;border-radius:6px;font-weight:600;
  }
  .pkg-table-wrap{overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;}
  .pkg-table{
    display:grid;
    grid-template-columns:200px repeat(3,1fr);
    grid-auto-rows:min-content;
    min-width:820px;
  }
  .pkg-table > *{
    padding:16px 18px;
    display:flex;align-items:center;
    border-bottom:1px solid rgba(255,255,255,0.08);
    font-size:14px;
    min-width:0;
  }
  .row-label{
    color:rgba(255,255,255,0.5);
    font-family:'IBM Plex Mono',monospace;
    font-size:12.5px;
    letter-spacing:0.02em;
    position:sticky;left:0;
    background:var(--ink);
    z-index:2;
  }
  .cell{color:rgba(255,255,255,0.85);}
  .cell .yes{color:#4EDB93;font-weight:700;margin-right:6px;}
  .cell .no{color:rgba(255,255,255,0.28);}
  .row-head{
    border-bottom:none;
    align-items:flex-start;
    flex-direction:column;
    padding-top:28px;
  }
  .row-head.row-label{background:transparent;}
  .plan-name{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:700;color:#fff;}
  .plan-price{font-family:'Bricolage Grotesque',sans-serif;font-size:30px;font-weight:700;color:#fff;margin-top:10px;}
  .plan-price span{font-family:'IBM Plex Mono',monospace;font-size:12px;font-weight:400;color:rgba(255,255,255,0.5);}
  .plan-desc{font-family:'Inter',sans-serif;font-size:12.5px;color:rgba(255,255,255,0.5);margin-top:8px;line-height:1.5;}
  .row-cta{border-bottom:none;padding-top:20px;padding-bottom:32px;align-items:flex-start;}
  .pkg-cta{
    text-align:center;
    width:100%;
    padding:12px 0;
    border-radius:var(--r-pill);
    font-weight:600;font-size:13.5px;
    background:rgba(255,255,255,0.08);
    color:#fff;
    transition:all .15s;
  }
  .pkg-cta:hover{background:#fff;color:var(--ink);}

  .col-featured{
    background:linear-gradient(180deg, rgba(30,122,82,0.14), rgba(30,122,82,0.03));
    position:relative;
  }
  .col-featured::before{
    content:"";
    position:absolute;top:0;left:0;right:0;bottom:0;
    border-left:1.5px solid var(--brand);
    border-right:1.5px solid var(--brand);
    pointer-events:none;
  }
  .row-head.col-featured{border-top-left-radius:var(--r-sm);border-top-right-radius:var(--r-sm);}
  .row-head.col-featured::before{border-top:1.5px solid var(--brand);border-radius:var(--r-sm) var(--r-sm) 0 0;}
  .row-cta.col-featured{border-bottom-left-radius:var(--r-sm);border-bottom-right-radius:var(--r-sm);}
  .row-cta.col-featured::before{border-bottom:1.5px solid var(--brand);border-radius:0 0 var(--r-sm) var(--r-sm);}
  .col-featured .pkg-cta{background:var(--brand);}
  .col-featured .pkg-cta:hover{background:#4EDB93;color:var(--ink);}
  .badge{
    display:inline-block;
    background:var(--brand);color:#fff;
    font-family:'IBM Plex Mono',monospace;
    font-size:10px;letter-spacing:0.06em;
    padding:4px 10px;border-radius:var(--r-pill);
    font-weight:600;margin-bottom:10px;
  }
  .pkg-note{
    margin-top:32px;font-size:13.5px;color:rgba(255,255,255,0.5);
    font-family:'IBM Plex Mono',monospace;line-height:1.7;
    border-left:2px solid var(--brand);padding-left:16px;
  }
  @media (max-width:920px){
    .pkg-table{grid-template-columns:150px repeat(3,190px);}
  }

  /* ---------- About ---------- */
  .about .wrap{display:grid;grid-template-columns:0.85fr 1.15fr;gap:64px;align-items:center;}
  .about-visual{
    background:var(--brand-light);
    border-radius:var(--r-lg);
    padding:40px;
    position:relative;
  }
  .stat-line{display:flex;justify-content:space-between;align-items:center;padding:18px 0;border-bottom:1px solid rgba(20,21,26,0.08);}
  .stat-line:last-child{border-bottom:none;}
  .stat-line .num{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:30px;color:var(--brand-dark);}
  .stat-line .lbl{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);max-width:150px;text-align:right;line-height:1.4;}
  blockquote{
    font-size:22px;line-height:1.5;color:var(--ink);
    font-weight:600;margin:0 0 22px;
    font-family:'Bricolage Grotesque',sans-serif;
  }
  .attribution{font-size:14px;color:var(--ink-soft);}
  .attribution b{color:var(--ink);}

  /* ---------- Sample sites ---------- */
  .sites-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
  .site-card{
    border:1px solid var(--border);
    border-radius:var(--r-md);
    padding:28px;
    background:var(--surface);
    transition:transform .18s, box-shadow .18s;
  }
  .site-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
  .idx{
    display:inline-flex;width:34px;height:34px;border-radius:10px;
    align-items:center;justify-content:center;
    font-family:'IBM Plex Mono',monospace;font-size:12px;
    background:var(--brand-light);color:var(--brand-dark);
    margin-bottom:16px;
  }
  .site-card h3{font-size:19px;margin-bottom:8px;}
  .site-card p{font-size:14.5px;color:var(--ink-soft);margin-bottom:18px;}
  .site-card a.visit{font-size:13.5px;font-weight:600;color:var(--ink);}

  /* ---------- Contact / footer ---------- */
  .contact{text-align:center;}
  .contact-card{
    background:linear-gradient(135deg, var(--brand) 0%, #12513A 100%);
    border-radius:var(--r-lg);
    padding:72px 40px;
    color:#fff;
    margin:0 20px;
  }
  .contact h2{font-size:38px;margin-bottom:16px;color:#fff;}
  .contact p{color:rgba(255,255,255,0.75);font-size:16.5px;max-width:520px;margin:0 auto 32px;}
  .contact .cta-row{justify-content:center;}
  .contact .btn-primary{background:#fff;color:var(--ink);}
  .contact .btn-primary:hover{background:var(--coral-light);}
  .contact .btn-ghost{border-color:rgba(255,255,255,0.35);color:#fff;}
  .contact .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,0.08);}

  footer{padding:44px 0;}
  .footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;}
  .footer-inner .fnav{display:flex;gap:24px;flex-wrap:wrap;}
  .footer-inner a{color:var(--ink-soft);font-size:13.5px;}
  .footer-inner a:hover{color:var(--ink);}
  .footer-tag{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-faint);}

  /* ---------- Responsive ---------- */
  @media (max-width:920px){
    .links{display:none;}
    .call-btn{display:none;}
    .hamburger{display:block;}
    .hero .wrap{grid-template-columns:1fr;}
    .hero h1{font-size:38px;}
    .stack{height:280px;margin-top:20px;}
    .services-grid{grid-template-columns:1fr;}
    .packages-card{border-radius:24px;padding:56px 22px;}
    .about .wrap{grid-template-columns:1fr;}
    .sites-grid{grid-template-columns:1fr;}
    .section-head h2{font-size:29px;}
    .contact-card{margin:0 12px;padding:48px 24px;}
    .footer-inner{flex-direction:column;text-align:center;}
  }

/* ---------- WP nav menu compatibility (Appearance > Menus) ---------- */
.links li,
.mobile-panel li{list-style:none;}
.links .current-menu-item > a,
.mobile-panel .current-menu-item > a{color:var(--ink);}
